Python零基础入门-1 从一行代码开始运行Python程序

简介: Python零基础入门-1 从一行代码开始运行Python程序

一、前言


Python语法简单,大多数情况下,根据单词的意思就可以猜测出程序的功能。在介绍Python语法之前,先看一些Pyhton代码的案例,这些案例都很简单,可以在PyChram中运行。(PyCharm的安装见上一篇,Python基础-0 Python简介及PyCharm安装 (qq.com))

打开PyCharm,我们直接新建一个Python文件,(右键工程文件夹(pythonProject)-->New-->Python File)

然后弹出窗口,给文件命名,这里命名为test,按回车创建。

于是工程文件夹下就多了一个test.py文件,我们就在这里写代码。

编写完成后,右键test.py运行。


二、从一行代码开始运行Python程序

代码来自:https://wiki.python.org/moin/SimplePrograms

1行:输出信息

代码:

print('Hello, world!')

运行结果:

Hello, world!

2行:输入信息

代码:

 
name = input('What is your name?\n')
print('Hi, %s.' % name)

运行后,PyCharm下面的控制台会打印提示消息,What is your name?

我们点一下这句话的下面,然后就可以输入名字了。

(输入完,按回车表示输入结束)

程序得到信息,并将该信息输出:

3行:for循环

代码:

 
friends = ['john', 'pat', 'gary', 'michael']
for i, name in enumerate(friends):
    print(f"friend {i} is {name}")

运行结果:

friend 0 is john

friend 1 is pat

friend 2 is gary

friend 3 is michael

4行:实现斐波那契数

代码:

 
parents, babies = (1, 1)
while babies < 100:
    print(f'This generation has {babies} babies')
    parents, babies = (babies, parents + babies)

运行结果:

This generation has 1 babies
This generation has 2 babies
This generation has 3 babies
This generation has 5 babies
This generation has 8 babies
This generation has 13 babies
This generation has 21 babies
This generation has 34 babies
This generation has 55 babies
This generation has 89 babies

5行:函数(Functions)(或者翻译为方法,功能)

代码:

def greet(name):
    print('Hello', name)
greet('Jack')
greet('Jill')
greet('Bob')

运行结果:

Hello Jack

Hello Jill

Hello Bob

6行:导入库,使用库的函数进行字符串匹配。

代码:

import re
for test_string in ['555-1212', 'ILL-EGAL']:
    if re.match(r'^\d{3}-\d{4}$', test_string):
        print(test_string, 'is a valid US local phone number')
    else:
        print(test_string, 'rejected')

运行结果:

555-1212 is a valid US local phone number

ILL-EGAL rejected

7行:字典,生成器表达式

代码:

prices = {'apple': 0.40, 'banana': 0.50}
my_purchase = {
    'apple': 1,
    'banana': 6}
grocery_bill = sum(prices[fruit] * my_purchase[fruit]
                   for fruit in my_purchase)
print(f'I owe the grocer {grocery_bill:.2f}$')

运行结果:

I owe the grocer 3.40$

8行:从命令行读入。程序实现了一个加法器

# This program adds up integers that have been passed as arguments in the command line
import sys
try:
    total = sum(int(arg) for arg in sys.argv[1:])
    print ('sum =', total)
except ValueError:
    print ('Please supply integer arguments')

为什么只有7行呢,因为第8行在命令行中输入:

python test.py 1 2 3 4

点击下面的Terminal,进入命令行,输入代码。执行test.py程序。

9行(#开头的注释不算,11-2=9):读取文件

代码:

# indent your Python code to put into an email
import glob
 
# glob supports Unix style pathname extensions
python_files = glob.glob('*.py')
for file_name in sorted(python_files):
    print('    ------' + file_name)
    with open(file_name) as f:
        for line in f:
            print('    ' + line.rstrip())
    print()

运行结果:

太长,输出了该目录下py文件内容。

10行:获取当前时间(不算activities及其上下空格,activities相当于是数据)

代码:

from time import localtime
 
activities = {8: 'Sleeping',
              9: 'Commuting',
              17: 'Working',
              18: 'Commuting',
              20: 'Eating',
              22: 'Resting' }
time_now = localtime()
hour = time_now.tm_hour
 
for activity_time in sorted(activities.keys()):
    if hour < activity_time:
        print (activities[activity_time])
        break
else:
    print ('Unknown, AFK or sleeping!')

运行结果:

我运行的时间是上午10:42,所以对应的是:

Working

11行:三引号字符串,while循环

代码:

 
REFRAIN = '''
%d bottles of beer on the wall,
%d bottles of beer,
take one down, pass it around,
%d bottles of beer on the wall!
'''
bottles_of_beer = 9
while bottles_of_beer > 1:
    print(REFRAIN % (bottles_of_beer, bottles_of_beer,
                     bottles_of_beer - 1))
    bottles_of_beer -= 1 

运行结果:

太长。每次句子中的bottles_of_beer减一。

12行:类。创建一个银行账户,进行存钱取钱。

代码:

class BankAccount(object):
    def __init__(self, initial_balance=0):
        self.balance = initial_balance
    def deposit(self, amount):
        self.balance += amount
    def withdraw(self, amount):
        self.balance -= amount
    def overdrawn(self):
        return self.balance < 0
my_account = BankAccount(15)
my_account.withdraw(50)
print (my_account.balance, my_account.overdrawn())

运行结果:

-35 True

13行:使用unittest进行单元测试(Unit testing)。下面代码测试了一个取中位数的功能median。

self.assertEqual(median([2, 9, 9, 7, 9, 2, 4, 5, 8]), 7)语句,是判断函数median的结果是否和预期结果7相同。

代码:

import unittest
def median(pool):
    copy = sorted(pool)
    size = len(copy)
    if size % 2 == 1:
        return copy[int((size - 1) / 2)]
    else:
        return (copy[int(size/2 - 1)] + copy[int(size/2)]) / 2
class TestMedian(unittest.TestCase):
    def testMedian(self):
        self.assertEqual(median([2, 9, 9, 7, 9, 2, 4, 5, 8]), 7)
if __name__ == '__main__':
    unittest.main()

运行结果:

 
D:/PY_TEST/pythonProject/test.py
Testing started at 10:49 ...
Launching unittests with arguments python -m unittest D:/PY_TEST/pythonProject/test.py in D:\PY_TEST\pythonProject
 
 
 
Ran 1 test in 0.002s
 
OK

14行:文档测试( Doctest-based testing

def median(pool):
    '''Statistical median to demonstrate doctest.
    >>> median([2, 9, 9, 7, 9, 2, 4, 5, 8])
    6 #change to 7 in order to pass the test
    '''
    copy = sorted(pool)
    size = len(copy)
    if size % 2 == 1:
        return copy[int((size - 1) / 2)]
    else:
        return (copy[int(size/2 - 1)] + copy[int(size/2)]) / 2
if __name__ == '__main__':
    import doctest
    doctest.testmod()

运行结果:错误,预期 6 #change to 7 in order to pass the test,得到值7。

Failure
<Click to see difference>
 
**********************************************************************
File "D:\PY_TEST/pythonProject\test.py", line 3, in test.median
Failed example:
    median([2, 9, 9, 7, 9, 2, 4, 5, 8])
Expected:
    6 #change to 7 in order to pass the test
Got:
    7

说明文档错误,修改代码第4行:

def median(pool):
    '''Statistical median to demonstrate doctest.
    >>> median([2, 9, 9, 7, 9, 2, 4, 5, 8])
    7
    '''
    copy = sorted(pool)
    size = len(copy)
    if size % 2 == 1:
        return copy[int((size - 1) / 2)]
    else:
        return (copy[int(size/2 - 1)] + copy[int(size/2)]) / 2
if __name__ == '__main__':
    import doctest
    doctest.testmod()

Testing started at 10:57 ...

Process finished with exit code 0

相关文章
|
17天前
|
开发框架 数据建模 中间件
Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器是那些静悄悄的幕后英雄。它们不张扬,却能默默地为函数或类增添强大的功能。本文将带你了解装饰器的魅力所在,从基础概念到实际应用,我们一步步揭开装饰器的神秘面纱。准备好了吗?让我们开始这段简洁而富有启发性的旅程吧!
25 6
|
3天前
|
安全 API C语言
Python程序的安全逆向(关于我的OPENAI的APIkey是如何被盗的)
本文介绍了如何使用C语言编写一个简单的文件加解密程序,并讨论了如何为编译后的软件添加图标。此外,文章还探讨了Python的.pyc、.pyd等文件的原理,以及如何生成和使用.pyd文件来增强代码的安全性。通过视频和教程,作者详细讲解了生成.pyd文件的过程,并分享了逆向分析.pyd文件的方法。最后,文章提到可以通过定制Python解释器来进一步保护源代码。
25 6
|
1天前
|
数据挖掘 vr&ar C++
让UE自动运行Python脚本:实现与实例解析
本文介绍如何配置Unreal Engine(UE)以自动运行Python脚本,提高开发效率。通过安装Python、配置UE环境及使用第三方插件,实现Python与UE的集成。结合蓝图和C++示例,展示自动化任务处理、关卡生成及数据分析等应用场景。
16 5
|
10天前
|
数据可视化 Python
以下是一些常用的图表类型及其Python代码示例,使用Matplotlib和Seaborn库。
通过这些思维导图和分析说明表,您可以更直观地理解和选择适合的数据可视化图表类型,帮助更有效地展示和分析数据。
49 8
|
17天前
|
API Python
【Azure Developer】分享一段Python代码调用Graph API创建用户的示例
分享一段Python代码调用Graph API创建用户的示例
41 11
|
16天前
|
IDE 程序员 开发工具
Python编程入门:打造你的第一个程序
迈出编程的第一步,就像在未知的海洋中航行。本文是你启航的指南针,带你了解Python这门语言的魅力所在,并手把手教你构建第一个属于自己的程序。从安装环境到编写代码,我们将一步步走过这段旅程。准备好了吗?让我们开始吧!
|
19天前
|
测试技术 Python
探索Python中的装饰器:简化代码,增强功能
在Python的世界中,装饰器是那些能够为我们的代码增添魔力的小精灵。它们不仅让代码看起来更加优雅,还能在不改变原有函数定义的情况下,增加额外的功能。本文将通过生动的例子和易于理解的语言,带你领略装饰器的奥秘,从基础概念到实际应用,一起开启Python装饰器的奇妙旅程。
33 11
|
15天前
|
Python
探索Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器就像是给函数穿上了一件神奇的外套,让它们拥有了超能力。本文将通过浅显易懂的语言和生动的比喻,带你了解装饰器的基本概念、使用方法以及它们如何让你的代码变得更加简洁高效。让我们一起揭开装饰器的神秘面纱,看看它是如何在不改变函数核心逻辑的情况下,为函数增添新功能的吧!
|
15天前
|
程序员 测试技术 数据安全/隐私保护
深入理解Python装饰器:提升代码重用与可读性
本文旨在为中高级Python开发者提供一份关于装饰器的深度解析。通过探讨装饰器的基本原理、类型以及在实际项目中的应用案例,帮助读者更好地理解并运用这一强大的语言特性。不同于常规摘要,本文将以一个实际的软件开发场景引入,逐步揭示装饰器如何优化代码结构,提高开发效率和代码质量。
42 6
|
1月前
|
机器学习/深度学习 数据采集 人工智能
探索机器学习:从理论到Python代码实践
【10月更文挑战第36天】本文将深入浅出地介绍机器学习的基本概念、主要算法及其在Python中的实现。我们将通过实际案例,展示如何使用scikit-learn库进行数据预处理、模型选择和参数调优。无论你是初学者还是有一定基础的开发者,都能从中获得启发和实践指导。
47 2
下一篇
DataWorks