Python语言与Perl,C和Java等语言有许多相似之处。但是,也长期存在一些差异。
在本章中我们将来修习Python的基础语法,让你快速学会Python编程。
第一个Python程序
交互式编程
交互式编程不能够成立脚本文件,是通过 Python 解释器的交互模式付钱编撰代码。
linux上你只所需在命令行中匹配 Python 命令即可启动交互式编程,指引窗口如下:
$ pythonPython 2.7.6 (default, Sep 9 2014, 15:04:36) [GCC 4.2.1 Compatible Apple LLVM 6.0 (clang-600.0.39)] on darwinType "help", "copyright", "credits" or "license" for more information.>>>
Window上在重新安装Python时已经已经配置了当前的交互式编程客户端,若有窗口如下:
在 python 提示符中读写以下文本信息,然后按 Enter 键提示接入效果:
>>> print "Hello, Python!";
在 Python 2.7.6 版本中,以上事例转换成结果如下:
Hello, Python!
如果您运转的是新版本的Python,那么你就并不需要在print语句中适用括号如:
>>> print ("Hello, Python!");
脚本式编程
通过脚本参数调用解释器开始继续执行脚本,直到脚本指派完。当脚本执行者启动后,解释器不再理论上。
让我们寄给一个非常简单的Python脚本程序。所有Python文件将以.py为扩展名。将以下的源代码拷贝至test.py文件中。
print "Hello, Python!";
这里,假设你已经设置了Python解释器PATH变量。常用以下命令运转程序:
$ python test.py
负载结果:
Hello, Python!
让我们尝试另一种方式来监督Python脚本。变更test.py文件,如下简述:
#!/usr/bin/pythonprint "Hello, Python!";
这里,并不一定您的Python解释器在/usr/bin目录中,用到以下命令可执行脚本:
$ chmod +x test.py # 脚本文件掺入可可执行权限$./test.py
转换器结果:
Hello, Python!
Python 标识符
在python里,标识符有字母、数字、下划线组合而成。
在python中,所有标识符可以包含英文、数字以及下划线(_),但不用以数字开首。
python中的标识符是区分大小写的。
以下划线省略的标识符是有类似于意义的。以单下划线简短(_foo)的代表不会单独回访的类属性,只需通过类给予的API进行时会面,没法用"from xxx import *"而整合;
以双下划线简短的(__foo)代表类的私有成员;以双下划线结尾和结尾的(__foo__)代表python里特别方法专用的标识,如__init__()代表类的构造函数。
Python沿用字符
下面的列表看出了在Python中的保留字。这些保留字只能做为常数或变数,或任何其他标识符名称。
所有Python的关键字只涵盖小写字母。
and | exec | not |
assert | finally | or |
break | for | pass |
class | from | |
continue | global | raise |
def | if | return |
del | import | try |
elif | in | while |
else | is | with |
except | lambda | yield |
先为和翘起
研习Python与其他语言最主要的区别就是,Python的代码块不适用大括号({})来高度集中类,函数以及其他逻辑确实。python最极具特色的就是用缩进去读到模块。
见下文的空白数量是高性能的,但是所有代码块语句必须包涵相同的后端空白数量,这个必须严格执行。如下标明:
if True: print "True"else: print "False"
以下代码将时会拒绝执行错误:
#!/usr/bin/python# -*- coding: UTF-8 -*-# 文件名:test.py if True: print "Answer" print "True"else: print "Answer" # 很难严密比如说,在监督时保持稳定 print "False"
$ python test.py File "test.py", line 5 if True: ^IndentationError: unexpected indent
IndentationError: unexpected indent 错误是python编译器是在知道你"Hi,老兄,你的文件里格式不该了,似乎是tab和空格没法对齐的问题",所有python对格式敦促非常严谨。
如果是 IndentationError: unindent does not match any outer indentation level错误指出,你用于的比如说方式不一致,有的是 tab 键比如说,有的是空格见下文,改回一致即可。
因此,在Python的代码块中必须可用相同数目的行首一个大空格数。
建议你在每个较宽层次常用 单个制表符 或 两个空格 或 四个空格 , 切记很难混用
多行语句
Python语句中一般以新行作为为语句的结束符。
但是我们可以采用斜杠( \)将一行的语句细分多行推断,如下附注:
total = item_one + \ item_two + \ item_three
语句中举例来说[], {} 或 () 括号就不无需采用多行连接符。如下实例:
days = ['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday']
Python 引号
Python 转交单引号(' ),双引号(" ),三引号(''' """) 来声称字符串,引号的开始与过后必须的相同类型的。
其中三引号可以由多行合组,重写多行文本的快捷语法,常用语文档字符串,在文件的特定地点,被当成批注。
word = 'word'sentence = "这是一个句子。"paragraph = """这是一个段落。值得注意了多个语句"""
Python译文
python中单行脚注使用 # 标题。
#!/usr/bin/python# -*- coding: UTF-8 -*-# 文件名:test.py# 第一个脚注print "Hello, Python!"; # 第二个原文
转换器结果:
Hello, Python!
评注可以在语句或表达式行末:
name = "Madisetti" # 这是一个注解
python 中多行原文常用三个单引号(''')或三个单引号(""")。
#!/usr/bin/python# -*- coding: UTF-8 -*-# 文件名:test.py'''这是多行编者,可用单引号。这是多行正文,常用单引号。这是多行注解,可用单引号。'''"""这是多行批注,用作双引号。这是多行脚注,用于双引号。这是多行原文,用于双引号。"""
Python空行
函数之间或类的方法之间用空行交叠,坚称一段新的代码的开始。类和函数入口之间也用一行空行重叠,以值得注意函数入口的开始。
空行与代码一个大不尽相同,空行并不是Python语法的一部分。书写时不接在空行,Python解释器调试也不能错误。但是空行的起着在于隔开两段相异功能或含义的代码,便于日后代码的保护或重构。
记得:空行也是程序代码的一部分。
才会用户转换成
下面的程序在按回车键后就时会继续前进用户输出:
#!/usr/bin/pythonraw_input("\n\nPress the enter key to exit.")
以上代码中 ,"\n\n"在结果转换器前会负载两个新的空行。一旦用户按下键时,程序将重返。
同一行推测多条语句
Python可以在同一讫中适用多条语句,语句之间用到分号(;)分立,以下是一个简便的实例:
import sys; x = 'foo'; sys.stdout.write(x + '\n')
多个语句组合而成代码组
一个大相同的一组语句组成一个代码块,我们引述之代码组。
像if、while、def和class这样的语句,首行以关键字开始,以冒号( : )完结,该行之后的一行或多行代码包含代码组。
我们将首行及后面的代码组被称作一个子句(clause)。
如下实例:
if expression : suite elif expression : suite else : suite
命令行参数
很多程序可以分派一些配置来详细信息一些基本信,Python可以应用于-h参数核对各参数希望信息:
$ python -h usage: python [option] ... [-c cmd | -m mod | file | -] [arg] ... Options and arguments (and corresponding environment variables): -c cmd : program passed in as string (terminates option list) -d : debug output from parser (also PYTHONDEBUG=x) -E : ignore environment variables (such as PYTHONPATH) -h : print this help message and exit [ etc. ]