python2.0 s12 day2


s12 day2 视频每节的内容

05 python s12 day2 python编码   1.第一句python代码     python 执行代码的过程     文件读到内存 分析内容 编译字节码 转换机器码 cpu调用   2.python解释器     执行时加python python hello.py     或者在文件头写入#/usr/bin/env python3.5     ./hello.py   3.python的版本     cpy     jpy     pypy 这个和其他的不同之处,在于编译时先编译成字节码,转换成机器码是在编译时做的,执行时cpu直接调用机器码。     其他python是编译时,只编译成字节码,执行时先转换成机器码,然后cpu调用。所以pypy同其他版本的py,程序运行时要快。   4.python内容编码问题     字符编码的种类,8位表示1个字符 (8位一个字节)     asicii码 8位表示1个字符,可以表示256个字符     unicode 至少16位(至少2个字节) 表示一个字符     utf-8 是对unicode的 一个优化,如果字符属于以前ascii码表示的字符,都按照8位存,如果是欧洲一些字符用16位存(2个字节),汉字用24位存(3个字节) 06 python s12 day2 接收执行参数   1注释     单行注释     多行注释   2.执行脚本传入参数     使用sys模块     import sys       sys.argv 07 python s12 day2 Python字符串原理剖析   1.pyc文件     执行python代码时,如果导入了其他的.py文件,那么,执行过程中会自动生成一个与其同名的.pyc文件(字节码文件),该文件就是python解释器编译后的字节码文件。.pyc文件存在了,把原文件删掉了,程序也可以执行,因为python优先找.pyc文件,如果没找到先生成在执行。python内部有检测文件与.pyc文件的一致性。     注释:代码经过编译可以产生字节吗;字节码通过反编译也可以得到代码   2.变量     变量命名     变量的作用     缓冲池:python内部有缓冲机制。减少内存负担     缓冲池:python中对数字和字符串的一个机制,当数字小于257时(大于或等于就超出了),多个变量引用这个数字时,python指引到一个内存块,当超过257时,python将不指向这个内存块。字符串同样有一个临界值。(这个值怎么定义的,不清楚。知道有临界就行。)       数字举例:       >>> i1 = 7       >>> i2 = 7       >>> id(i1)       140348026316520       >>> id(i2)       140348026316520       >>> i3 = 257       >>> i4 = 257       >>> id(i3)       140348026351544       >>> id(i4)       140348026351520           >>>        这个缓冲区的作用是提高内存的利用率和执行效率。i1 = 7 ,i2 = 7理论上需要分配到两块内存块中,python为了提高效率做了一个优化指向同一块内存,将一些常用类型的数据的值放到缓冲区,提供了这么一个缓冲机制。把python认为常用的放到缓冲池中。   3.输入输出     input()     #当我们输入密码时,不希望显示出来,可以导入python的getpass模块来实现     import getpass     pwd = getpass.getpass(“请输入您的密码:”)     print(pwd)   4.流程控制     if...else...     while   5.基本的数据类型     1)数字       int(整型)       long 长整型       float 浮点型       complex 复数 (基本用不到)     2布尔值       真或假       1或0     3字符串       字符串原理 08 python s12 day2 基本数据类型常用方法       字符串的3种格式化方法       万恶的+       字符串常用功能:       移除空白 .strip()       分割 str.split()       长度 len(str)       索引 str[0]       切片     4列表       创建列表的2种方法:         a = [‘x’,’y']         a = list(('x','y’))       列表的常见方法:         索引         切片         追加 list.append()         删除 list.pop() list.remove() del         长度 len(str)         循环 for,while           continue;break;pass;return;exit(0,1,2..)         包含 x in list     5元祖       元祖的元素不可修改         (11,22,33)         (11,22,{’k1’:’v1'})       元祖的元素如果是一个字典,字典是可以修改,但不能删除         a = (11,22,{'k1':'v1’})         a[2]['k2'] = ‘v2’         a         (11, 22, {'k2': 'v2', 'k1': 'v1’})       其他的功能和列表一样     6)字典       创建字典的两种方式:         a = {‘k1’:’v1’,’k2’:’v2'}         a = dict(‘k1’=‘v1’,’k2’=‘v2’)       字典的常用方法:         索引 d[key]         新增 d[key] = xx         删除 del d[key]         键、值、键值对           keys values items         循环           for k,v in dic.items()         长度   6.运算符 09 python s12 day2 上周作业实例分析 直播里看过了,此节跳过 10 python s12 day2 Python主文件判断   1.主入口文件     使用文件的__name__ == ‘__main__’ 属性判断,如果不是主程序文件则显示 文件名是不带.py 11 python s12 day2 一切事物都是对象   1.类的简单介绍     1)对于python ,一切事物都是对象,对象基于类创建     创建对象,对象中有很多方法。创建对象时,并不是在对象中同时 创建了方法。而是实例化类时创建了对象,并告诉这个对象,你是我这个 类的儿子老子这里有很多功能,你记住这些功能集合的列表的内存地 址,回头就根据这个内存地址首先找到功能集合列表,根据集合的内容去 找里面的方法。   还可以这样理解:

类创建对象:创建了对象和给对象一个指引到类的指引标志。告诉类,如果用类的某些功能,通过这个指引标记找到类,类来执行。

    2)python来说所有事物都是对象       对象是基于类创建的       对象具有的所有的功能都是根据内存地址去类中找的。调用类里面的成员。     3)查看类的方法       type()方法查看类型       dir()查看有哪些方法       help()查看详细的方法 12 python s12 day2 int内部功能介绍   按照类的方式来看看数据类型     type()查看对象的类型     如果是内置的类,直接显示对象类型     如果是安装的外部包,查看对象类型显示的是那个类在什么位置     >>> from twisted.internet import reactor     >>> print type(reactor)     <class 'twisted.internet.selectreactor.SelectReactor'>   1.整数类 int     a = 18     bit_length()二进制位的长度s     a.__abs__()绝对值,因为是比较常用的功能,并且方法又是带下划线的,python就把这个功能放到内置函数里面里了。所以就有了abs()     abs(-19) abs()内部做两件事,先是拿到这个数字创建int对象,然后调用这个对象的.__abs__()     a.__add__() 同__abs__,而且python在语法堂中定义成1+1,内部就是拿前面一个数字创建对象,然后调用__add__()     a.__cmp__ 比较,python3.5里就没有了     a.__and__     a.__bool__     a.__divmod__这个有用,用于得到商和余数       >>> divmod(8,2)       (4, 0)     a.__eq__()是否相等     a.__flot__()转换成浮点型     a.__floordiv__()地板除,语法堂 5//6       >>> a.__floordiv__(6)       0     a.__ge__() 大于等于返回True,>=     a.__hash__()创建对象时有一个哈西值 13 python s12 day2 float和long内部功能介绍   2.flot浮点型和int类似     .as_integer_ratio 就这一个怪异的,把浮点型转化成最简比的分数比如0.5转成1/2     long长整型 和int类似的 14 python s12 day2 str内部功能介绍一   3.字符串     1)所有语言百分之八十都是对字符串和集合的操作     2)str的常用操作       a = ‘eric’         使用dir(a)查看字符串有哪些成员。         这里我们首要关注成员里的方法         用到模块的时候用vars()不仅列出成员,成员值也列出来       a.__contains__(‘er’) 包含返回true 语法堂 ‘er’ in a       a.__eq__() 字符串的相等 语法堂 ==       __format__ 字符串的格式化,         >>>a = ‘eric{0}’         >>>a.__format__(‘alex’)         >>> a.format('alex’)         ‘alexalex'       __getattribute__() 反射的时候会用到它,暂时到这这个方法        __getitem__() 类的时候用到。这个方法暂时到这 语法堂 str[0]       a.capitalize()首字符大写了         >>> a.capitalize()         ‘Alex’       a.casefold() 将大写字符变小些         >>> a = 'alExV5'         >>> a.casefold()         ‘alexv5'       a.center这个有用         >>> print(8*'*',a,8*'*')         ******** alExV5 ********用center可以实现         >>> a.center(20)         ' alExV5 ‘         >>> a.center(20,'*’)         '*******alExV5*******’       a.count(‘a')计算字符出现的次数。还可以定义起始位置和结束位置       a.count(‘a’,0,10) 从位置0到为止10统计       a.encode()将字符串转编码         >>> a = '李杰’         >>> a.encode('gbk’)        b'\xc0\xee\xbd\xdc'       a.endswith() 判断是不是以什么结尾的,如果是返回true,也可以加起始位置和结束位置,判断子序列是不是以什么结尾的 15 python s12 day2 str内部功能介绍二       a.expandtabs()将tabs转换成空格,默认情况下将一个tabs转换成8个空格         >>> a = 'a\tlex’         >>> a.expandtabs()         'a lex’       a.find() 找某个字符,返回这个字符的位置,可以设置找的起始位置和结束位置,如果找的字符不存在,返回-1       a.index() 也是找,和find的不同,找不到的时候直接抛出异常报错       a.format() 就是做字符串格式化的,内部调用__format__()         两种写法         >>> a = "alex {0} as {1}”         >>> a.format('sb','eric’)         'alex sb as eric’         >>> a ="alex {name} as {id}”         >>> a.format(name='sb',id = 'eric’)         'alex sb as eric’       isalnum()是否是字母或者数字       isalpha()是否是字母       isdecimal()是否是10进制小数       isdigit()是否是数字       isidentifier()是否是关键字       islower()是否全部是小写       isnumeric()是否是数字       isprintable()是否可以打印,忽略       isspace()是否是空格       istitle()是否是标题,判断每一个字母首字母都是大写       isupper()是否全部是大写       ‘’,join(list) 拼接       ljust() 和center功能相似,左对齐       rjust()       lower() 全部变成小写       lstrip()       maketrans()做一个对应表,和translate()结合使用,来做替换       translate()         >>> intab = 'abcde’         >>> outtab = ‘12345'         >>>trantab = ''.maketrans(intab,outtab)           >>> trantab         {97: 49, 98: 50, 99: 51, 100: 52, 101: 53}         >>> l_str = 'this is a ,that is bc'         >>> l_str.translate(trantab)         'this is 1 ,th1t is 23'       partition() 做分割,把字符串分割成3部分         >>> a = 'alexissb’         >>> a.partition('is’)         ('alex', 'is', 'sb’)       replace()替换       replace(‘old’,’new’,个数)       rfind()从右向左找       split()       splitlines()根据行分割,没有它用split(‘\n')也能实现       strip()       startswith()以什么开头       swapcase() 大小写转换       title() 将字符串中所有的字母的首字母大写       upper() 大写       zfill() 16 python s12 day2 上下文管理剖析   2.with的用法     with open(‘h.log’,’r’) as f_read:       f_readlines     with 的意思是执行完后继续调用函数,原理如下:下面的语句不能执 行 哦,只是原理展示     def f():       print(‘11111’) 1.先打印1111       yield 2.碰到 yield了,记录函数的位置,并跳出函数       print(‘333333’) 4.with语句块执行完后在打印这个     with f():       print(‘我插一杠子’) 3.紧接着打印这句 17 python s12 day2 list内部功能介绍   3.     1)列表的2种构建方式:       li = list([1,2])       li = [1,2,3]     2)列表的常用方法:       append() 尾部添加       clear() 把列表清空       copy() 拷贝浅拷贝       count() 判断元素出现的次数       extend() 扩展一个列表,参数可以是列表也可以是元组         大家以后再写列表或者元组的时候一定在最后加一个逗号[1,2,3,] (1,2,3,)       index() 查找返回下标,找不到抛异常,可以加查找起始位置 和结束位置       insert() 插入指定位置,insert(0,’sb’)       pop() 参数为下标位置,移除并返回元素值,下标位置不存在 时抛出异常,报错,       remove() 参数为元素值,移除,不返回元素值,只返回执行状态,当参数 值不存在时,抛出异常       reverse()反转,列表反转。       sort() 按字符编码排序 18 python s12 day2 tuple和dict内部功能介绍   4.元组     1)元组的2种创建方式       t1 = (1,2,)       t1 = tuple((1,2)) 或 tuple([1,2])     2)元组的常用方法:       (略) 19 python s12 day2 字典和列表课上练习题   5.字典     1)字典的2种创建方式       a= {‘k1’,’v1’}       a = dict(k1= 'v1’)     2)字典的常用方法:       clear()清空       copy() 浅拷贝       fromkeys()         >>> a = a.fromkeys(['k1','k2'],'v1')         >>> a         {'k2': 'v1', 'k1': 'v1’}       get()方法获得值,如果参数key不存在,返回空值       a.values()       a.keys()       a.items()       a.pop()删除,参数key,删除并获得value       a.popitem() 删除随机删除键值对,没用       setdefault(k,v) 两个参数,如果k键存在,则返回值,如果不存在将加入字典,并且值为’v’       update() 完结!!!

优质内容筛选与推荐>>
1、iptables的相关概念和数据包的流程(图)
2、一些开源的Google项目
3、行逻辑链接的矩阵乘法
4、个人博客网站(四) - 后端项目
5、C#和Qt实现的对于异常处理的一个使用策略


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号