珀耳塞福建 发表于 2018-8-8 06:52:51

Python基础--Python3基础语法

  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 ... [-c cmd | -m mod | file | -] ...
  
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 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)
  

  注意事项:
  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.
页: [1]
查看完整版本: Python基础--Python3基础语法