Python 3.x 基本语法

编码

默认情况下,Python 3 源码文件以UTF-8编码,所有字符串都是unicode字符串。当然你也可以为源码文件指定不同的编码:

#-*- coding:gbk -*-  或者 # coding=gbk   符号 = 两边没有空格

标示符

  • 第一个字符必须是字母表中的字母或下划线
  • 标示符的其他部分由字母、数字和下划线组成
  • 标示符对大小写敏感

在Python 3 中,非 ASCII 标示符也是允许的。

Python 保留字

保留字即关键字,我们不能把他们用作任何标示符的名称。Python 的标准库提供了一个 keyword 模块,可以输出当前版本的所有关键字:

>>>import keyword

>>>keyword.kwlist

['False','None','True','and','as','assert','break','class','continue','def','del','elif','else','except','finally','for','from','global','if','import','in','is','lambda','nonlocal','not','or','pass','raise','return','try','while','with','yield']

注释

Python 中单行注释以 # 开头,多行注释以'''或"""开头和结尾,也可以用多个#号,实例如下:

#!/usr/bin/env python

# 第一个注释
print ("Hello, Python!") # 第二个注释


'''多行注释
第一种
多行注释'''


"""多行注释
第二种
多行注释"""
注释

执行上面代码,输出结果为:

Hello World!
执行结果

多行注释可以用多个#号:

#!/usr/bin/python3

# 第一个注释
# 第二个注释

print ("Hello, Python!") 
多行注释

执行上面代码输出结果为:

Hello, Python!
执行结果

行与缩进

Python最具特色的就是使用缩进来表示代码块,不需要使用大括号{}。

缩进的空格数是可变的,但是同一个代码块的语句必须包含相同的缩进空格数。实例如下:

if True:
    print("True")
else:
    print("False")
示例

以下代码最后一行语句缩进数的空格数不一致,会导致运行错误:

if True:
    print("Answer")
    print("True")
else:
    print("Answer")
  print("False")     # 缩进不一致,会导致运行错误!
错误示例

以上程序由于缩进不一致,执行后会出现类似以下错误:

File "C:/Users/Administrator/PycharmProjects/Zero/day1/1.py", line 10
    print("False")     # 缩进不一致,会导致运行错误!
                                       ^
IndentationError: unindent does not match any outer indentation level
报错

多行语句

Python 通常是一行写完一条语句,但如果语句很长,我们可以使用反斜杠 "\" 来实现多行语句,例如:

total = "item_one+"\
        "item_two+"\
        "item_three"
print(total)
多行示例

在[],{},或()中的多行语句,不需要使用反斜杠 ”\“ ,例如:

total = ['item_one', 'item_two', 'item_three',
'item_four', 'item_five']
多行示例

数据类型

Python中数有四种类型:整数、长整数、浮点数和复数

  • 整数,如1
  • 长整数,是比较大的整数
  • 浮点数,如1.23、3E-2
  • 复数,如 1+2j、1.1+2.2j

字符串

  • Python中单引号和双引号使用完全相同
  • 使用三个引号('''或""")可以指定一个多行字符串
  • 转义符 "\"
  • 自然字符串,通过在字符串前加 r 或 R 。如 r"this is a line with \n" 则 \n 会显示,并不是换行
  • Python允许处理Unicode字符串,加前缀 u 或 U,如 u"this is an unicode string" 。
  • 字符串是不可变的
  • 按字面意义级联字符串,如 "this" "is" "string"会被自动转换位 this is string 。
word = "字符串"
sentence = "这是一个句子"
paragraph = """这是一个段落
可以有多行组成"""
示例

空行

函数之间或类的方法之间用空行分隔,表示一段新的代码的开始。类和函数入口之间也用一个空行分隔,以突出函数入口的开始。

空行与代码缩进不同,空行并不是Python语法的一部分。书写时不插入空行,Python解释器运行也不会出错。但是空行的作用在于分隔两段不同功能或含义的代码,便于日后代码的维护或重构。

注意:空行也是程序代码的一部分。

等待用户输入

执行下面的程序在按回车键后就会等待用户输入:

#!/usr/bin/env python
#-*-coding:utf-8 -*-
# Author:Zero
input("\n\n按下 enter 键后退出。")
示例

以上代码中, "\n\n"在输出前会输出两个新的空行,一旦用户按下 enter 键时,程序退出。

同行显示多条语句

Python可以在同一行中使用多条语句,语句之间使用分号 ";"分割,以下是一个简单的实例:

#!/usr/bin/env python
#-*-coding:utf-8 -*-
# Author:Zero
import sys; x = "Zero"; sys.stdout.write(x + "\n")

#多个模块(库)可以使用逗号 “,” 分割

#!/usr/bin/env python
#-*-coding:utf-8 -*-
# Author:Zero
import sys; x = "Zero"; sys.stdout.write(x + "\n")

import sys,os,getpass
示例

上面代码输出结果为:Zero

多个语句构成代码组

缩进相同的一组语句构成一个代码块,我们称之为代码组。

像 if、while、def 和 class 这样的复合语句,首行关键字开始,以冒号 “:” 结束,该行之后的一行或多行代码构成代码组。

我们将首行及后面的代码组称为一个子句(clause)。实例如下:

if expression :
    suite
elif expression :
    suite
else:
    suite

# 这里的express 是表达式,suite是继续!即if后面接的是表达式,suite是if表达式成立后的各种输出或执行程序
示例

Print 输出

print 默认输出是换行的,如果要实现不换行需要在变量末尾加上 end="" :

#!/usr/bin/env python
#-*-coding:utf-8 -*-
# Author:Zero

x = "a"
y = "b"
# 换行输出
print(x)
print(y)

print("---------------")
# 不换行输出
print(x,end="")
print(y,end="")
print("-----------------")
示例

以上示例执行输出结果为:

C:\Users\Administrator\AppData\Local\Programs\Python\Python36\python.exe C:/Users/Administrator/PycharmProjects/Zero/day1/1.py
a
b
---------------
ab-----------------

Process finished with exit code 0
执行结果

import 与 from...import

在 Python 用 import 或者 from...import 来导入相应的模块(库)。

将整个模块(somemodule)导入,格式为: import somemodule 例--> import datetime (导入整个datetime包)

从某个模块中导入某个函数,格式为: from somemodule import somefunction 例--> from datetime import datetime(导入datetime包里的datetime类)

将摸个模块中的全部函数导入,格式为:from somemodule import *   例--> from datetime import *(导入datetime包里的所有类)

实例:

import sys
print("----------Python import mode-----------")
print("命令行参数为:")
for i in sys.argv:
    print(i)
    print("\n python 路径为",sys.path)
导入sys模块
from sys import argv,path  # 导入特定的成员

print("---------python import mode-------------")
print("path:",path) # 因为已经导入path成员,所以此处引用时不需要加sys.path
导入sys模块的argv,path成员

命令行参数

很多程序可以指向以下操作来查看一些基本信息,Python可以使用-h参数查看各参数帮助信息:

C:\Users\Administrator>python -h
usage: python [option] ... [-c cmd | -m mod | file | -] [arg] ...
Options and arguments (and corresponding environment variables):
-b     : issue warnings about str(bytes_instance), str(bytearray_instance)
         and comparing bytes/bytearray with str. (-bb: issue errors)
-B     : don't write .pyc files on import; also PYTHONDONTWRITEBYTECODE=x
-c cmd : program passed in as string (terminates option list)
-d     : debug output from parser; also PYTHONDEBUG=x
-E     : ignore PYTHON* environment variables (such as PYTHONPATH)
-h     : print this help message and exit (also --help)
-i     : inspect interactively after running script; forces a prompt even
         if stdin does not appear to be a terminal; also PYTHONINSPECT=x
-I     : isolate Python from the user's environment (implies -E and -s)
-m mod : run library module as a script (terminates option list)
-O     : optimize generated bytecode slightly; also PYTHONOPTIMIZE=x
-OO    : remove doc-strings in addition to the -O optimizations
-q     : don't print version and copyright messages on interactive startup
-s     : don't add user site directory to sys.path; also PYTHONNOUSERSITE
-S     : don't imply 'import site' on initialization
示例

一些注释的意思

#!/usr/bin/python3 

第一行注释标的是指向Python的路径,告诉操作系统执行这个程序的时候,调用/usr/bin 下的Python解释器。

此外还有以下形式(推荐写法):

#!/usr/bin/env python3

这种用法现在 env (环境变量)设置里查找 Python 的安装路径,再调用对应路径下的解释器程序完成操作

'''......''' 或 """......."""" 三引号之间书写较长的注释,还可以用于在函数的首部对函数进行一个说明:

def example(anything):
    '''形参为任意类型的对象,
       这个示例函数会将其原样返回。
    '''
    return anything

help() 函数

调用Python的help()函数可以打印输出一个函数的文档字符串:

# 如下实例,查看 max 内置函数的参数列表和规范的文档
>>> help(max)
……显示帮助信息……

按下:q 两个按键即退出说明文档

如果仅仅想得到文档字符串:

>>> print(max.__doc__)    # 注意,doc的前后分别是两个下划线
max(iterable, *[, default=obj, key=func]) -> value
max(arg1, arg2, *args, *[, key=func]) -> value

With a single iterable argument, return its biggest item. The
default keyword-only argument specifies an object to return if
the provided iterable is empty.
With two or more arguments, return the largest argument.

 

posted @ 2017-11-23 17:39  零之寒怒  阅读(341)  评论(0编辑  收藏  举报