Python基础--Python3基础语

发布时间:2019-09-27 07:06:38编辑:auto阅读(1816)

    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.


关键字