首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

python-3_函数_匿名函数_正则_

L=['a','b','c','d'] for (offset,item) in enumerate(L):     print offset,item 打印的结果: 0 a 1 b 2 c 4 d 迭代器: for i in range(100):     生成列表 for i in xrange(100)    迭代器,速度会比range快 readlines()    xreadlines() a=iter(list) 生成迭代器 a.next() 节省内存:只记录迭代的开头和结尾,当前位置。 和函数一起使用,可以使函数中断并保存函数的中断状态,yield,可以减少程序的阻塞 例子: def run():     print "test1"     yield 1                #变成迭代器,程序运行到这里会停止跳到外面的执行。yield相当于返回值。     time.sleep(1)     print "test2"     time.sleep(1)     print "test2"     time.sleep(1)     print "test2"     time.sleep(1) task=run() task.next() print '--do sth else---' task.next()        #如果不加本行,就不会执行yield后面的。 函数: 函数中可以直接修改全局的列表 字典等复杂的数据类型。 lambda函数(匿名函数): def f(x):    return x**2     g = lambda x:x**2  匿名函数的写法 print map(f,range(10))   把列表输入函数运算,再返回结果 print map(lambda x:x**2,range(10)) sorted()用法:例子是对字典key进行排序(虽然字典是无序的) dic1={3:2,4:3,6:9,'a':'test','e':'fff','*':'$'} print sorted(dic1.items(),key=lambda x:x[0]) rgs kargs 内置函数: a=range(10) a=iter(a)    #把列表变成了迭代器 a.next() print [i for i in a if a<5] filter(lambda x:x*x,a)  选出符合的元素 a=[1,2,3,4]  b=[5,6,7,8,9,10] zip(a,b) [(1,5),(2,6),(3,7),(4,8)] map(None,a,b) [(1,5),(2,6),(3,7),(4,8),(none,9),(none,10)] reduce(lambda x,y:x+y,a) 序列化: 硬盘上只能存字符串或者二进制,因此不能存字典,列表等。 pickle 只是python中使用的序列化类型。 pickle.dump(对象,文件句柄)  pickle.load()    pickle.dump(dic1,f) json.dump()  json.load() 正则表达式: m = re.match("\d",匹配的对象)   match是从开头匹配。 查看匹配到字符: m.group()            re.search()全局查找匹配 re.findall() 查找所有匹配到的 re.split()  按照符号分割 re.sub('\d',"|",字符对象)   把梳子全部替换成| re.sub('\d',"|",字符对象,count=2)  只替换前两个 模块的创建和导入: if __name__=='__main__'   主动执行会执行,导入不执行 常用模块: Import sys Sys.path Sys.path Sys.exit Import os os.system('uname') Os.mkdir('myDir') Os.chdir('~')

01

Python学习笔记整理(十三)Pyth

一、模块 模块是Pyhon最高级别的程序组织单元,它将程序代码和数据封装起来以便重用。实际的角度,模块往往对应Python程序文件。 每个文件都是一个模块,并且模块导入其他模块之后就可以使用导入模块定义的变量名。模块可以由两个语句和一个重要的内置函数进行处理。 import: 使客户端(导入者)以一个整体获取一个模块。 from:容许客户端从一个模块文件中获取特定的变量名。 reload:在不中止Python程序的情况下,提供了一个重新载入模块文件代码的方法。 在一个模块文件的顶层定义的所有变量名都成为了被导入的模块对象的属性。 模块至少有三个角色: 代码重用:模块还是定义变量名的空间,被认作是属性。可以被多个外部的客户端应用。 系统命名空间的划分: 现实共享服务和数据: 1、python程序构架 一个ptyhon程序包括了多个含有Python语句的文件。程序是作为一个主体的,顶层的文件来构造的,配合有零个或多个支持文件,在Python中这些文件称作模块。 标准模块:python自带了200多个使用的模块、成为标准连接库 import如何工作 执行三个步骤 1)、找到模块文件 2)、编译成位码(需要时) 3)、执行模块的代码来创建其所定义的对象。 在之后导入相同的模块时候,会跳过这三个步骤,而只提取内存中已加载模块对象。 搜索模块 导入模块时,不带模块的后缀名,比如.py Python搜索模块的路径: 1)、程序的主目录 2)、PTYHONPATH目录(如果已经进行了设置) 3)、标准连接库目录(一般在/usr/local/lib/python2.X/) 4)、任何的.pth文件的内容(如果存在的话).新功能,允许用户把有效果的目录添加到模块搜索路径中去 .pth后缀的文本文件中一行一行的地列出目录。 这四个组建组合起来就变成了sys.path了, >>> import sys >>> sys.path 导入时,Python会自动由左到右搜索这个列表中每个目录。 第1,第3元素是自动定义的,第2,第4可以用于扩展路径,从而包括自己的源码目录。 import b的形式可能加载 源码文件b.py 字节码文件.pyc 目录b 编译扩展模块,比如linux的b.so 用C编写的编译好的内置模块,并通过静态连接至Python ZIP文件组件,导入时自动解压压缩。 java类型,在Jython版本的python中。 .NET组件,在IronPython版本中的Python中 脚本中随处可见 object.attribute这里表达式法:多数对象都有一些可用的属性。可以通过"."运算符取出。 有些是可调用的对象。例如,函数。 第三方工具:distutils 第三方扩展,通常使用标准连接库中的distutils工具来自动安装。使用distutils的系统一般附带setup.py脚本 命令空间是一种独立完备的变量包,而变量就是命名空间对象的属性。模块的命令空间包含了代码在模块文件顶层赋值的所有变量名(也就是没有嵌套与def和class语句中) 二、模块代码编写基础 1、模块的创建和使用。 创建模块 后缀.py文本文件,模块顶层指定的所有变量名都会变成其属性。 定义一个module.py模块 name='diege' age=18 def printer(x):         print x 使用模块 import全部导入 >>> import module 属性 >>> module.name 'diege' 函数 >>> module.printer('hi') hi >>> module.printer('9')  9 from语句 from将获取(复制)模块特定变量名 from 模块名 import 需要复制的属性 from 模块名 import 需要复制的属性 as 新的属性名 from会把变量名赋值到另一个作用域,所以它就可以让我们直接在脚本中使用复制后的变量名,而不是通过模块 >>> from module import name >>> name 'diege >>> from module import name as myname >>> myname 'diege' >>> from module import printer as PR >>> PR('hi python') hi python >>> PR('99')         99 from * 语句 from 模块名 import * 取得模块顶层所有赋了值的变量名的拷贝。 模块只导入一次,因为该操作开销大 import和from是赋值语句,是可执行

05
领券