Python简介
python的创始人为吉多·范罗苏姆(Guido van Rossum)。1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC语言的一种继承。
Python的特点
Python 优点 1.简单、优雅、明确 2.强大的模块第三方库 3.易移植 4.纯面向对象语言 5.可扩展性良好(cjavac#。。。) Python缺点 1.代码不能加密 2.执行速度慢 Python能做什么 1.软件开发 1.游戏后台、搜索、图形界面 2.网站 3.CS软件 4.科学运算 2.系统管理 1.脚本 2.IT自动化工具
Python的编码风格
1 1.分号 2 不要在行尾加分号,也不要用分号将两条命令放在一行 3 4 2.行长度 5 每行不超过80个字符 6 7 3.括号 8 除非是用于实现行连接,否则不要在返回语句或条件语句中使用括号,不过在元祖两边使用括号还是可以的 9 10 4.缩进 11 用4个空格来缩进代码 12 13 5.空行 14 顶级定义之间空两行,方法定义之间空一行[类2行,函数1行] 15 16 6.空格 17 按照标准的排版规范来使用标点两边的空格 18 19 7.SheBang 20 大部分.py文件不必以#!作为文件的开始。根据PEF-394,程序的main文件应该以 21 #!/usr/bin/python2或#!/usr/bin/python3开始 22 23 8.注释 24 确保对模块、函数、方法和行内注释使用正确的风格 25 26 9.类 27 如果一个类不继承自其它类,就显示的从object继承,嵌套类也一样 28 29 10.字符串 30 即使参数都是字符串,使用%操作符或者格式化方法格式化字符串,不过也不能一概而论,你需要在+和%之间好好判定 31 32 11.文件和sockets 33 在文件和sockets结束时,显式的关闭它 34 35 12.TODO注释 36 为临时代码使用TODO注释,它是一种短期解决方案,不算完美,但够用就好 37 38 13.导入格式 39 每个导入应该独占一行 40 41 14.语句 42 通常每个语句应该独占一行 43 44 15.访问控制 45 在Python中,对于琐碎又不太重要的访问函数,你应该直接使用公有变量来取代它们, 46 这样可以避免额外的函数调用开销,当添加更多功能时,你可以用属性(prorerty)来保持语法的一致性 47 48 16.命名 49 1.所谓”内部(Internal)”表示仅模块内可用, 或者, 在类内是保护或私有的. 50 2.用单下划线(_)开头表示模块变量或函数是protected的(使用import * from时不会包含). 51 3.用双下划线(__)开头的实例变量或方法表示类内私有. 52 4.将相关的类和顶级函数放在同一个模块里. 不像Java, 没必要限制一个类一个模块. 53 5.对类名使用大写字母开头的单词(如CapWords, 即Pascal风格), 但是模块名应该用小写加下划线的方式(如lower_with_under.py). 54 尽管已经有很多现存的模块使用类似于CapWords.py这样的命名, 但现在已经不鼓励这样做, 因为如果模块名碰巧和类名一致, 这会让人困扰. 55 56 17.Main 57 即使是一个打算被用作脚本的文件,也应该是可以导入的。并且简单的导入不应该导致 58 这个脚本的主功能(main functionality)被执行,这是一种副作用。主功能应该放在一个mian()函数中
Python指定解释器
这是脚本语言共同遵守的规则:当第一行为 #!/path/to/script/interpreter时,指定了用来执行本脚本的解释器。 注意: 1、必须是文件的第一行 2、必须以#!开头,你丢了一个惊叹号 3、/path/to/script/interpreter是脚本解释器的全路径名。 例如: #!/bin/sh shell脚本 #!/usr/bin/perl perl脚本 #!/usr/bin/python python脚本 #!/usr/bin/python3 python3脚本 #!/usr/bin/python2 python2脚本 而有时不太清楚脚本解释器的具体全路径名;或者开发环境与运行环境的安装路径不同。为了保证兼容性,也可以写作: #!/usr/bin/env python3 这样运行时会自动搜索脚本解释器的绝对路径。 /usr/bin是一个系统目录,里面存储一些系统命令,可执行程序。 类似windows操作系统的C:WindowsSystem32目录
Python注释
#单行注释 eg: #这是个单行注释 #多行注释 eg: '''多行注释 多行注释 多行注释 ''' #单引号与多引号,没区别
Python变量运算
#变量→可变的量 例如: x = 2 y = 3 #常量→不可变的量、默认不变 PAI = 3.141592654 写代码的时候,一般小写的表示变量,大写表示常量 >>> x = 2 >>> z = x >>> print('z:',z) z: 2 >>> x = 5 >>> print('x:',x) x: 5 >>> print('z:',z) z: 2 >>> 当创建x = 2时,解释器干了两件事 1.在内存中,创建了一个名为2的数字 2.在内存中创建了一个名为x的变量,并把它指向2 z = x 1.把z指向x所指向的2 x = 5 1.把x重新指向了5,(又重新开辟了一块内存) >>> a = 1 >>> id(a) 491282656 >>> a = 2 >>> id(a) 491282688 >>> 语法要求: 1.缩进统一 2.变量: 1.标识符的第一个自反目必须是字母表中的字母(大写或小写)或者一个下划线(‘_’) 2.标识符名称的其他部分可以是由字母(大写或小写)、下划线(“_”)或数字(0-9)组成 3.标识符名称是对大小写敏感的,例如,myname和myName不是一个标识符。注意前者中的小写n和后者中的大写N 4.有效标识符名称例子i,_my_name,name_123和a1b1 无效标识符名称列子2thing、 this is 和my-name #----------------------------------------数据类型[特征划分]------------------------------------------- 1.数字类型 1.整型 1.布尔型:True False 2.长整型(L) 存的数据大 3.标准整型 存的数据小 [当存的数据长的时候,Python自动转换] 2.非整型 1.双精度浮点型(float) 2.复数 3.decimal(不是内建类型) 2.序列类型[数组] 1.字符串(str) 2.元祖(tuple) 3.列表(list) 3.映像类型 1.字典(dict) 4.集合类型 1.可变集合(set) 2.不可变集合(frozenset) #----------------------------------------数据类型[可变性划分]------------------------------------------- 1.不可变数据类型 1.数字类型 2.不可变集合(frozenset) 3.字符串(str) 4.元祖(tuple) 2可变数据类型 1.字典(dict) 2.列表(list) 3.可变集合(set) #----------------------------------------算术运算------------------------------------------- + 相加 - 相减 * 相乘 / 相除 % 取余 ** a**b a的b次方 // 取整除 #----------------------------------------比较运算------------------------------------------- == 等于 != 不等于 <> 不等于 > 大于 < 小于 >= 大于等于 <= 小于等于 #----------------------------------------赋值运算------------------------------------------- = 简单的赋值运算符 += 加法赋值运算符, c += a 等效于c = c+a -= 减法赋值运算符, c -= a 等效于c = c-a *= 乘法赋值运算符, c *= a 等效于c = c*a /= 除法赋值运算符, c /= a 等效于c = c/a %= 取模赋值运算符, c %= a 等效于c = c%a **= 幂赋值运算符, c **= a 等效于c = c**a //= 取整除赋值运算符, c //= a 等效于c = c//a #----------------------------------------位运算------------------------------------------- 128 64 32 16 8 4 2 1 0 0 0 0 1 0 1 0 = 10 0 0 0 1 0 1 0 0 = 20 & 按位与[两个都为真]: 10 % 20 = 0 | 按位或[一个为真则为真]:10 | 20 = 1 1 1 1 0 = 30 ^ 按位异或[两个一样为假,两个不一样则为真]: 10 ^ 20 = 1 1 1 1 0 = 30 ~ 按位取反[相反] 所有正整数的按位取反是其本身+1的负数、所有负整数的按位取反是其本身+1的绝对值、零的按位取反是 -1 << 左移动: 10 << 2 = 0 0 1 0 1 0 0 0 = 40 >> 右移动: 10 >> 2 = 0 0 0 0 0 0 1 0 = 2 #----------------------------------------逻辑运算------------------------------------------- and 与 or 或 not 非 #----------------------------------------成员运算------------------------------------------- in 在指定序列则返回True not in 不在指定序列则返回True #----------------------------------------成员运算------------------------------------------- is 判断标识符是否引自一个对象: id(20)is id(20) is not 判断标识符是不是引自不同的对象: id(20)is not id(30)
Python字符编码
# 字符编码 ASSIC Unicode UTF-8 256 2**8 ASSIC 8位一个字节 ord('a'):查看对应的字母、数字、符号对应的数字 一个字节变成2个字节 65536 2**16 Unicode 存储占两个字节 UTF-8 三个字节存一个汉字 ,解决Unicode占容量大的问题 gbk 每个汉字表对应ASSIC一个数字 Python默认ASSIC s = u'中文' s_encode = s.encode('utf-8') print(s_encode) s_decode = s_encode.decode('utf-8') print(s_decode) #result 》》b'xe4xb8xadxe6x96x87' 》》中文 encode 转码 unicode→utf-8 decode 解码 以unicode读取到内存,utf-8存储到硬盘 #指定编码格式 例: # coding:utf-8 #_*_coding:utf-8 _*_
Python模块导入
#导入模块 <!--import语句--> 导入Python源文件,只需在另一个源文件执行import语句 import module >>> import os >>> os.system('adb devices') List of devices attached adb server is out of date. killing... * daemon started successfully * 596cb85a device <!--保存dos命令行内容--> >>> import os >>> a = os.popen('adb devices').read() >>> a 'List of devices attached 596cb85a device ' #subprocess 命令行操作 》》import sys 》》print(sys.argv[0]) 取执行脚本后面的参数 <!--别名--> import multiprocessing as mult <!--from..import语句--> Python的from语句让你从模块中导入一个指定的部分到当前命名空间 from modname import name1 》》import sys impot argv <!--from..import*语句--> 把一个模块的所有内容全部导入到当前命名空间 from modname import *
Python流程控制
#流程控制 if...else 》》 name = input('please input your name') global age global msg for i in range(10): age = int(input('age')) if age > 29: msg = 'this smaller!' elif age == 29: msg = '