Python3 基础语法

编码

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

# -*- coding: cp-1252 -*-


标识符

1.第一个字符必须是字母表中字母或下划线;

2.标识符的其他的部分有字母、数字和下划线组成;

3.标识符对大小写敏感。

注:在Python3中,非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/python3
#第一个注释
print ("Hello,Python!") #第二个注释

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

Hello,Python!

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

#!/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/wuli/PycharmProjects/test.py", line 10
    print("False")    #缩进不一致,会导致运行错误
                                    ^
IndentationError: unindent does not match any outer indentation level


多行语句

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

total = 'item_one + \
        item_two + \
        item_three'


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

total = ['item_one','item_two','item_three',
 'item_four','item_five']


数据类型

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

1.整数,例如1

2.长整数,比较大的整数

3.浮点数,例如1.23、3E-2

4.复数,例如1+2j、1.1+2.2j 


字符串

1.Python中单引号和双引号使用完全相同;

2.使用三引号('''或""")可以指定一个多行字符串;

3.转义符'\'

4.自然字符串,通过在字符串前加r或R。例如:r"this is a line with \n"则\n会显示,并不是换行;

5.python允许处理Unicode字符串,加前缀u或U,例如:u"this is an unicode string"

6.字符串是不可变的。

7.按字面 意义级联字符串,例如:"this" "is" "string"会被自动转换为this is string

word = '字符串'

sentence = "这是一个句子"

paragraph = """这是一个段落,

可以有多行组成"""


空行

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

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

谨记:空行也是程序代码的一部分。


等待用户输入

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

#!/usr/bin/python3
input("\n\n按下enter键后退出。")


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


同一行显示多条语句

Python可以在同一行中使用多条语句,语句之间使用分号(;)分割,事例如下:

#!/usr/bin/python3
import sys; x = 'python';sys.stdout.write(x + '\n')


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

python


多个语句构成代码组

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

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

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

例如:

if expression:
    suite
elif expression:
    suite
else:
    suite


print输出

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

x = 'a'
y = 'b'
#换行输出
print(x)
print(y)
print('------')
#不换行输出
print(x,end=" ")
print(y,end=" ")
print()


以上执行结果为:

a
b
------
a b


import与from...import

在Python用import或者form...import来导入相应的模块。

将整个模块(somemodule)导入,格式为:import somemodule

从某个模块中导入某个函数,格式为:from somemodule import somefunction

从某个模块中导入多个函数,格式为:from somemodule import firstfunc,secondfunc,thirdfunc

将某个模块中的全部函数导入,格式为:from somemodule import *


导入sys模块

import sys
print('================Python import mode==========================');
print ('命令行参数为:')
for i in sys.argv:
    print (i)
print ('\n python 路径为',sys.path)


输出为:

================Python import mode==========================
命令行参数为:
C:/Users/wuli/PycharmProjects/Project20170523-python3/Day1/test1.py
 python 路径为 ['C:\\Users\\wuli\\PycharmProjects\\Project20170523-python3\\Day1', 
 'C:\\Users\\wuli\\PycharmProjects\\Project20170523-python3', 
 'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\python36.zip', 
 'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\DLLs', 
 'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\lib', 
 'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36', 
 'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\lib\\site-packages']


 

导入sys模块的argv,path成员

from sys import argv,path  #  导入特定的成员
 
print('================python from import===================================')
print('path:',path) # 因为已经导入path成员,所以此处引用时不需要加sys.path


输出为:

================python from import===================================
path: ['C:\\Users\\wuli\\PycharmProjects\\Project20170523-python3\\Day1', 
'C:\\Users\\wuli\\PycharmProjects\\Project20170523-python3', 
'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\python36.zip', 
'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\DLLs', 
'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\lib', 
'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36', 
'C:\\Users\\wuli\\AppData\\Local\\Programs\\Python\\Python36\\lib\\site-packages']



命令行参数

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

C:\Users\wuli>python3 -h
usage: python3 [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 .py[co] 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)
[etc.]


注意事项:

1. 在Windows下可以不写第一行注释:

#!/usr/bin/python3

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

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

#!/usr/bin/env python3

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


2. 关于注释,也可以使用''' '''的格式在三引号之间书写较长的注释;

''' '''还可以用于在函数的首部对函数进行一个说明:

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


3. help()函数

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

# 如下实例,查看 max 内置函数的参数列表和规范的文档

>>> help(max)
Help on built-in function max in module builtins:
max(...)
    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.


按下:q两个按键即退出说明文档(linux当中退出方式)

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

>>> 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.