Python 语法

Posted kernel001

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python 语法相关的知识,希望对你有一定的参考价值。

///////////////////////////////////////////////////
//
// Python 语法
//
////////////////////////////////////////////////////

一、Python 基本知识
【特点】
1. 跨平台
2. 面向对象
3. 像胶水,可以连接两个语言编程
4. 编程简单

【基本】
    1. 脚本解释说明
        #!/usr/bin/python   //在 unix/linux 下 才会有这句,windows下没有
    2. 编码方式说明
        # -*- coding: UTF-8 -*-     // 设置编码方式,否则会影响代码解释,输出
    3. 严格行和缩进
        1)不是用 等来控制,就意味着要严格控制行和缩进
        2)可用;显示多条语句(一般不这么做)
    4. 多行语句
        当一行语句写不完 可用 "\" 进行折行
【注释】
    1. 单行注释
        在单行代码行首 加 "#"
    2. 多行注释
        用一对三引号''' 或 """ 来包裹多行要注释的代码
    

二、Python 基本语法
【输入、输出】
键盘输入、屏幕输出.
1. 输入:
a. 数字型等
var = input()
b. 字符串型
var = raw_input() (python3 已舍弃)
返回一个字符串
2. 输出:
a. print
1)利用print + var1,var2,... 输出var (python3中已舍弃)
2)利用print(var) ,输出var
3) end关键字,可以不换行打印
关键字end可以用于将结果输出到同一行,或者在输出的末尾添加不同的字符
a, b = 0, 1
while b < 1000:
print(b, end=‘,‘)
a, b = b, a+b
b. write
利用sys模块中stdout对象之write(var) , 输出var
【变量】
1. 创建变量
var1,var2 = 初始值1,初始值2 #分别对var1,var2 进行初始化。

    2. 删除变量
        del 变量1,变量2
【数据类型】
    1. Numbers(数字)
        a. int(有符号整型)
        b. long(长整型[也可以代表八进制和十六进制])常用大写L表示   [Python3 中舍弃]
        c. float(浮点型)
        d. complex(复数)
            利用a+bj 表示,a 和 b 属于浮点型(数字型),j为复数常量
    2. String(字符串)
        a. 单引号  成对
            表示存粹的字符串,一切皆为字符串。
        b. 双引号 成对
            可以转义字符等。
        c. 三引号 成对
        
        d. Unicode 字符串
            在普通字符串前面加上u
    3. List(列表)
        list = [element1,element2,...]
        相当于C语言中数组   
        
        特点:
            可修改元素的值。
        访问:
            列表中值的切割也可以用到变量 [头下标:尾下标] ,就可以截取相应的列表,
            从左到右索引默认 0 开始,从右到左索引默认 -1 开始,下标可以为空表示取到头或尾。
            
            list[index]
        列表推导式
            vec = [2, 4, 6]
            >>> [3*x for x in vec]
            [6, 12, 18]
    4. Tuple(元组)
        tuple = (element1,element2,...)
        
        特点:
            一旦创建,不能修改 元素的值。
        访问:
            类似List(列表)
    5. Dictionary(字典)
        dict = 'key1':value1,'key2':value2,...)
        
        特点:
            可修改 键、值
        访问:
            dict[key]
    
    6. Set(集合) [Python3 数据类型]
    
        集合(set)是一个无序的不重复元素序列。
        创建:
            parame = value01,value02,...
            或者
            set(value)
        注:
            isinstance 和 type 的区别在于:
                type()不会认为子类是一种父类类型。
                isinstance()会认为子类是一种父类类型。
    
        不可变数据(3 个):Number(数字)、String(字符串)、Tuple(元组);
        可变数据(3 个):List(列表)、Dictionary(字典)、Set(集合)。
    7. 类型转换
        int(x [,base])
            将x转换为一个整数
        long(x [,base] )
            将x转换为一个长整数
        float(x)
            将x转换到一个浮点数
        complex(real [,imag])
            创建一个复数
        str(x)
            将对象 x 转换为字符串
        repr(x)
            将对象 x 转换为表达式字符串
        eval(str)
            用来计算在字符串中的有效Python表达式,并返回一个对象
        tuple(s)
            将序列 s 转换为一个元组
        list(s)
            将序列 s 转换为一个列表
        set(s)
            转换为可变集合
        dict(d)
            创建一个字典。d 必须是一个序列 (key,value)元组。
        frozenset(s)
            转换为不可变集合
        chr(x)
            将一个整数转换为一个字符
        unichr(x)
            将一个整数转换为Unicode字符
        ord(x)
            将一个字符转换为它的整数值
        hex(x)
            将一个整数转换为一个十六进制字符串
        oct(x)
            将一个整数转换为一个八进制字符串
【迭代器 & 生成器】

    迭代器:
        迭代是Python最强大的功能之一,是访问集合元素的一种方式。
            iter(集合变量) 
            next(集合变量)
            ###########################
            >>> list=[1,2,3,4]
            >>> it = iter(list)    # 创建迭代器对象
            >>> print (next(it))   # 输出迭代器的下一个元素
            1
            >>> print (next(it))
            2
        创建一个迭代器:
            把一个类作为一个迭代器使用需要在类中实现两个方法 __iter__() 与 __next__() 。
    生成器:
        在 Python 中,使用了 yield 的函数被称为生成器(generator)。
【运算符】
    1. 算术运算符
        +
            相加
        -   
            相减
        *
            相乘
        /
            相除
        %
            取模
        **
            取幂值
        //
            取整除  (返回商的整数部分)
    2. 比较运算符
    
        比较返回布尔值 False,True.
        == 
            比较俩对象是否相等
        !=
            比较俩对象是否不相等
        <>
            比较俩对象是否不相等
        >
            大于
        <
            小于
        >=
            大于等于
        <=
            小于等于
    3. 赋值运算符
        =
            赋值
        +=
            加法赋值
        -=
            减法赋值
        *=
            乘法赋值
        /=
            除法赋值
        %=
            取模赋值
        **=
            幂赋值
        //=
            取整除赋值
    4. 位运算符
        *  
            按位与
        |
            按位或
        ^
            按位异或
        ~   
            按位取反 类似于 -(x+1)
        <<
            左移运算符
        >>  
            右移运算符
    5. 逻辑运算符
        and 
            两者都为真,结果才为真
        or
            一者为真,结果为真
        not
            一者为假,结果为假
    6. 成员运算符
        in  
            1) 如果在指定的序列中找到值返回 True,否则返回 False。  
            2) x 在 y 序列中 , 如果 x 在 y 序列中返回 True。
        not in  
            1) 如果在指定的序列中没有找到值返回 True,否则返回 False。
            2) x 不在 y 序列中 , 如果 x 不在 y 序列中返回 True。
    7. 身份运算符
        a. is  
            比较两者是否是引用自同一个对象
        b. is not
            比较两者是否是引用自不同一个对象
【条件】
    1. if 判断条件:  执行语句(或者换行)
    
    2. if 判断条件:
            执行语句……
        else:
            执行语句……
            
    3. if 判断条件1:
            执行语句1……
        elif 判断条件2:
            执行语句2……
        elif 判断条件3:
            执行语句3……
        else:
            执行语句4……
【循环】
    1. while 循环
        1) while 判断条件:
            执行语句……
        2) while 判断条件:
            执行语句……
           else:   
            执行语句……  # while循环条件不成立时的执行语句
    2. for 循环
        1) for 元素 in 集合:
                执行语句……
        2) for 元素 in 集合:
                执行语句……
           else:
                执行语句…… #条件不成立时,执行语句
    3. 循环控制语句
        1) break
            跳出循环,且只能跳出1层。
        2) continue
            跳过当前循环,继续循环下去
        3) pass
    注:
        1. while 和 for 循环之间是可以互相嵌套使用的。
        2. break 、continue 只用于for、while循环中
        3. pass 可以用于任意结构中,意为什么也不做。
【函数】
    1. 定义函数
        def 函数名(参数表):
            执行语句
            return 返回值
        
        参数表:
            a. 可为数据类型
            b. 可用默认值,从右向左(一般)
            c. 不定长参数的函数定义
                def functionname([formal_args,] *var_args_tuple ):
                   "函数_文档字符串"
                   function_suite
                   return [expression]
                   
                注:
                    加了星号(*)的变量名会存放所有未命名的变量参数。
    2. 调用(使用)函数
        a = 函数名(参数表)
    3. 参数
        1) 不可更改
            a = 5
            a = 10 # 这里不是将a赋值为10,而是指向被new一个int 为10的数。
        2) 可更改
            而list、tuple、dictionary 是可更改的
    4. 匿名函数(lambda 表达式)
        lambda [arg1 [,arg2,.....argn]]:expression
            
【模块 & 包】
    搜索路径
        当你导入一个模块,Python 解析器对模块位置的搜索顺序是:
            1、当前目录
            2、如果不在当前目录,Python 则搜索在 shell 变量 PYTHONPATH 下的每个目录。
            3、如果都找不到,Python会察看默认路径。UNIX下,默认路径一般为/usr/local/lib/python/。
        模块搜索路径存储在 system 模块的 sys.path 变量中。变量里包含当前目录,PYTHONPATH和由安装过程决定的默认目录。
    
    1. 模块
        描述:
            Python 模块(Module),是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和Python语句。
        导入:
            描述:
                将该模块引用进来
            语法:
                a. import module1[, module2[,... moduleN]]
                    导入以上模块
                        如果有必要,也可以使用 [模块名.函数名] 来进行调用
                        
                        比如:
                            math.sin(30);
                b. from moduleName import name1[, name2[, ... nameN]]
                    从模块中导入一个指定的部分到当前命名空间中
                c. from moduleName import *
                    把一个模块的所有内容全都导入到当前的命名空间
        dir(moduleName) 函数:
            dir() 函数一个排好序的字符串列表,内容是一个模块里定义过的名字。
                返回的列表容纳了在一个模块里定义的所有模块,变量和函数
            
            特殊字符串变量__name__指向模块的名字,__file__指向该模块的导入文件名。
            
        globals() 和 locals() 函数
            根据调用地方的不同,globals() 和 locals() 函数可被用来返回全局和局部命名空间里的名字。
            如果在函数内部调用 locals(),返回的是所有能在该函数里访问的命名。
            如果在函数内部调用 globals(),返回的是所有在该函数里能访问的全局名字。
            两个函数的返回类型都是字典。所以名字们能用 keys() 函数摘取。

        reload() 函数
            当一个模块被导入到一个脚本,模块顶层部分的代码只会被执行一次。
            因此,如果你想重新执行模块里顶层部分的代码,可以用 reload() 函数。该函数会重新导入之前导入过的模块。
              语法如下:
                reload(module_name)
    2. 包
        包是一个分层次的文件目录结构,它定义了一个由模块及子包,和子包下的子包等组成的 Python 的应用环境。
        简单来说,包就是文件夹,但该文件夹下必须存在 __init__.py 文件, 该文件的内容可以为空。__init__.py 用于标识当前文件夹是一个包。
        
        考虑一个在 package_runoob 目录下的 runoob1.py、runoob2.py、__init__.py 文件,test.py 为测试调用包的代码,目录结构如下:
            test.py
                package_runoob
                |-- __init__.py
                |-- runoob1.py
                |-- runoob2.py
                
        导入包:
            from package_runoob.runoob1 import runoob1
            from package_runoob.runoob2 import runoob2
            
            runoob1()
            runoob2()
    3. 内置模块
        数学模块
            1)math
                数学模块(常用)
            2)cmath
                复数模块
【异常处理】
    1. try....except...else
        try:
            <语句>        #运行别的代码
        except <名字>:
            <语句>        #如果在try部份引发了'name'异常
        except <名字>,<数据>:
            <语句>        #如果引发了'name'异常,获得附加的数据
        else:
            <语句>        #如果没有异常发生
    2. try-finally
        try:
            <语句>
        finally:
            <语句>    #退出try时总会执行
        raise
        
【面向对象】
    1. 类
        创建类:
            class ClassName:
               '类的帮助信息'   #类文档字符串
                class_suite  #类体
            
        注:
            类的帮助信息可以通过ClassName.__doc__查看。
            class_suite 由类成员,方法,数据属性组成。
            
        实例: 
            #!/usr/bin/python
            # -*- coding: UTF-8 -*-
             
            class Employee:
               '所有员工的基类'
               empCount = 0
             
               def __init__(self, name, salary): 
                  self.name = name
                  self.salary = salary
                  Employee.empCount += 1
               
               def displayCount(self):
                 print "Total Employee %d" % Employee.empCount
             
               def displayEmployee(self):
                  print "Name : ", self.name,  ", Salary: ", self.salary
            
            特殊方法
                1) __init__(self):  
                    __init__ 为构造函数,self 为实力本身
                2) __del__(self):
                    析构函数,
        你也可以使用以下函数的方式来访问属性:
            getattr(obj, name[, default]) : 访问对象的属性。
            hasattr(obj,name) : 检查是否存在一个属性。
            setattr(obj,name,value) : 设置一个属性。如果属性不存在,会创建一个新属性。
            delattr(obj, name) : 删除属性。
        
        实例:
            hasattr(emp1, 'age')    # 如果存在 'age' 属性返回 True。
            getattr(emp1, 'age')    # 返回 'age' 属性的值
            setattr(emp1, 'age', 8) # 添加属性 'age' 值为 8
            delattr(emp1, 'age')    # 删除属性 'age'
    2. Python内置类属性
        __dict__ : 类的属性(包含一个字典,由类的数据属性组成)
        __doc__ :类的文档字符串
        __name__: 类名
        __module__: 类定义所在的模块(类的全名是'__main__.className',如果类位于一个导入模块mymod中,那么className.__module__ 等于 mymod)
        __bases__ : 类的所有父类构成元素(包含了一个由所有父类组成的元组)
    3. 类继承
        class 派生类名(基类名1,基类名2, ...)
            ...
            
        你可以使用issubclass()或者isinstance()方法来检测。
            issubclass() - 布尔函数判断一个类是另一个类的子类或者子孙类,语法:issubclass(sub,sup)
            isinstance(obj, Class) 布尔函数如果obj是Class类的实例对象或者是一个Class子类的实例对象则返回true。
        子类构造函数(方法):
            子类若需要父类的构造方法需要          
            1) 显示调用父类方法   (重写,创建时完成多态)
                    super(子类,self).__init__(参数1,参数2, ...)
                或
                    父类名称.__init__(self,参数1,参数2,...)
            2)  或者不写父类的构造方法
    4. 运算符重载
        __add__ 
        __str__
        __repr__
        __cmp__
            ...等 魔法方法
    5. 访问性
        默认为public型访问权限
        单下划线、双下划线、头尾双下划线说明:
            __foo__: 定义的是特殊方法,一般是系统定义名字 ,类似 __init__() 之类的。
            _foo: 以单下划线开头的表示的是 protected 类型的变量,即保护类型只能允许其本身与子类进行访问,不能用于 from module import *
            __foo: 双下划线的表示的是私有类型(private)的变量, 只能是允许这个类本身进行访问了。
            
        函数也是如此。

以上是关于Python 语法的主要内容,如果未能解决你的问题,请参考以下文章

python语法

Python学习Python 基础语法

python的基本语法

Python 基础语法

Python 基础语法

Python 基础语法