- 浏览: 193584 次
文章分类
最新评论
Python作为一种高效的脚本语言,内置了很多实用的函数,同时也提供了丰富的工具模块。 下面是总结的几种内置对象及函数的应用技巧。
1、强大的列表解析功能
- 对列表元素的简单操作:例如将列表的每个元素乘以2
list1 = [1,2,3,4] list1 = [x*2 for x in list1] #[2,4,6,8]
- 对文件的操作:例如只收集文件中以'p'开头的行
lines = [line.rstrip() for line in open('filename') if line[0] == 'p']
- 对两个集合进行排列组合:例如对'abc'与'lmn'进行排列组合
str1 = 'abc' str2 = 'lmn' [x+y for x in str1 for y in str2] #['al', 'am', 'an', 'bl', 'bm', 'bn', 'cl', 'cm', 'cn']
2、索引和分片
- 对字符串的操作
#索引操作 s = 'spam' s[0] # 's' s[-1] # 'm' #分片操作 s[1:3] # 'pa' s[1:] # 'pam' s[:-1] # 'spa' s[:] # 'spam' s[::2] # 'sa' s[1::2] # 'pm' s[::-1] # 'maps' s[-1:0:-1] # 'map'
- 对列表的操作
#索引操作 list1 = ['spam','SPAM','Spam'] list1[0] # 'spam' list1[-1] # 'Spam' #分片操作 list1[1:2] # ['SPAM'] list1[1:] # ['SPAM', 'Spam'] list1[:-1] # ['spam', 'SPAM'] list1[:] # ['spam', 'SPAM', 'Spam'] list1[::2] # ['spam', 'Spam'] list1[1::2] # ['SPAM'] list1[::-1] # ['Spam', 'SPAM', 'spam'] list1[-1:0:-1] # ['Spam', 'SPAM']
3、内置的eval函数可以将字符串转换成对象
a='123' type(a) # <type 'str'> type(eval(a)) # <type 'int'>
4、zip函数
- 内置的zip函数使用for循环实现并行遍历。在基本运算中,zip会取得一个或多个序列为参数,然后返回元组的列表,将这些序列中的并排的元素配成对。
>>> l1 = [1,2,3,4] >>> l2 = [5,6,7,8] >>> zip(l1,l2) [(1, 5), (2, 6), (3, 7), (4, 8)]
- 如果与 for 循环搭配,zip就会支持并行迭代
>>> for (x,y) in zip(l1,l2): ... print x, y, '--', x+y ... 1 5 -- 6 2 6 -- 8 3 7 -- 10 4 8 -- 12
- 在运行时构造字典
>>> keys = ['a', 'b', 'A', 'B'] >>> values = [96, 97, 65, 66] >>> d = dict(zip(keys, values)) >>> d {'a': 96, 'A': 65, 'B': 66, 'b': 97}
5、工厂函数 工厂函数有时也叫闭合(closure),一个能够记住嵌套作用域变量值的函数,尽管那个作用域或许已经不存在了。 尽管类是最适合用作记忆状态的,因为它们通过属性赋值这个过程变得很明了,像这样的函数也提供了一种替代的解决方法。
>>> def maker(n): ... def action(x): ... return x ** n ... return action ... >>> f=maker(2) >>> type(f) <type 'function'> >>> f(3) 9 >>> f(4) 16
6、匿名函数:lambda 除了def语句之外,Python还提供了一种生成函数对象的表达式形式。由于它于LISP语言中的一个工具很相似,所以称为lambda。就像def一样,这个表达式创建了一个之后能够调用的函数,但是它返回了一个函数而不是将这个函数赋值给一个变量名。这也就是lambda有时被称作匿名函数的原因了。
- lambda通常用来编写跳转表(jump table),也就是行为的列表或字典,能够按照需要执行相应的动作
- 行为列表示例:
>>> L = [(lambda x: x **2),(lambda x: x**3),(lambda x: x**4)] >>> for f in L: ... print f(2) ... 4 8 16
- 行为字典示例:
>>> key = 'got' >>> {'already':(lambda: 2+2),'got':(lambda: 2*4),'one':(lambda: 2**6)}[key]() 8
这样一个字典也就变成了一个多路分支的工具了
- 行为列表示例:
- lambda 与 if/else三元表达式的结合
>>> lower = lambda x,y: x if x < y else y >>> lower('a','b') 'a' >>> lower('b','a') 'a'
- 如果要在lambda函数中执行循环,能够嵌入map调用或列表解析表达式
- 嵌入map的示例
>>> import sys >>> showall = lambda x: map(sys.stdout.write,x) >>> t = showall(['spam\n','toast\n','eggs\n']) spam toast eggs >>> L = [1,2,3,4] >>> map((lambda x: x+3),L) [4, 5, 6, 7]
- 嵌入列表解析的示例
>>> showall = lambda x: [sys.stdout.write(line) for line in x] >>> t = showall(('bright\n','side\n','of\n','life\n')) bright side of life
- 嵌入map的示例
- 嵌套作用域和lambda
def func(): x = 4 action = (lambda n: x ** n) return action f = func() print f(2) #16, 4**2
7、生成器
- 概念 不像一般的函数会生成值后退出,生成器函数在生成值后自动挂起并暂停它们的执行和状态。正是因为这一点,无论是在从头计算整个序列的值,或者手动保存和恢 复类中的状态时,它们都常常作为一种使用的替代解决方案。生成器在被挂起时自动地保存状态,它的本地变量将保存状态信息,这些信息在函数恢复时将再度有效。
- 生成器函数和一般函数的区别:最大的区别就是生成器yield一个值,而不是return一个值。yield语句会将函数挂起,并向它的调用者返回一个值,但是保存足够的状态信息为了让其能够在函数从它挂起的地方恢复。这能够允许这些函数不断地产生一系列的值,而不是一次计算所有的值,之后将值以类似列表之类的形式来返回。
- 生成器函数在Python中与迭代器协议的概念联系在一起 包含了yield语句的函数将会特地编译为生成器。当调用是,它们返回了一个生成器对象,这个生成器对象支持迭代器对象接口。生成器函数也许有一个return语句,这个语句就是用来终止产生值的。
- 示例:
>>> def gensquares(n): ... for i in range(n): ... yield i ** 2 ... >>> type(gensquares(5)) <type 'generator'> >>> for i in gensquares(5): ... print i,',', ... 0 , 1 , 4 , 9 , 16 ,
- 生成器表达式: 生成器表达式就像一般的列表解析一样,但是它们是括在圆括号中而不是方括号中的。生成器表达式返回一个生成器对象。
>>> for x in (x ** 2 for x in range(4)): ... print x, ... 0 1 4 9>>> for x in (x ** 2 for x in range(4)): ... print x, ... 0 1 4 9
注意:如果生成器表达式是在其他括号之内的话,就像在那些函数调用之中,生成器自身的括号就不是必须的了。尽管这样,在下面第二个sorted调用中,还是需要额外的括号。>>> sum(x ** 2 for x in range(4)) 14 >>> sorted(x ** 2 for x in range(4)) [0, 1, 4, 9] >>> sorted((x ** 2 for x in range(4)), reverse=True) [9, 4, 1, 0] >>> import math >>> map(math.sqrt, (x ** 2 for x in range(4))) [0.0, 1.0, 2.0, 3.0]
1、math模块
>>> import math >>> math.pi 3.1415926535897931 >>> math.e 2.7182818284590451 >>> math.sin(2*math.pi/180) 0.034899496702500969
2、random模块
>>> import random >>> random.random() 0.40019449172525789 >>> random.random() 0.063811948555701825 >>> random.randint(1,10) 3 >>> random.randint(1,10) 2 >>> random.choice(['a', 'b', 'c']) 'a' >>> random.choice(['a', 'b', 'c']) ‘c'
3、decimal模块
>>> print 0.1+0.1+0.1-0.3 5.55111512313e-17 >>> from decimal import Decimal >>> Decimal('0.1')+Decimal('0.1')+Decimal('0.1')-Decimal('0.3') Decimal("0.0")
4、re正则表达式 re模块能够处理正则表达式的操作
- 生成正则表达式对象 compile(pattern, flags=0)构建一个正则表达式,返回该正则表达式对象
>>> import re >>> ptn1 = re.compile('he')
- 进行匹配
- match() 确定正则表达式是否匹配字符串的开头
- search() 扫描字符串以查找匹配
- findall() 找到所有正则表达式匹配的子字符串,并把它们作为一个列表返回
- finditer() 找到所有正则表达式匹配的子字符串,并把它们以迭代器的形式返回
- group() 返回通过正则表达式匹配到的字符串
- start() 返回成功匹配开始位置
- end() 返回成功匹配结束位置
- span() 返回包含成功匹配开始和结束位置的元组
>>> import re >>> p1 = re.compile('h') >>> str1 = 'hello world' >>> md = p1.match(str1) >>> print md <_sre.SRE_Match object at 0x7f28e95c3238> >>> md.group() 'h' >>> md.start() 0 >>> md.end() 1 >>> md.span() (0, 1) >>> p2 = re.compile('llo') >>> md2 = p2.search(str1) >>> md2.group() 'llo' >>> md2.span() (2, 5) >>> p3 = re.compile('\d+') >>> str2 = '12abc3de45' >>> print p3.findall(str2) ['12', '3', '45'] >>> iterator = p3.finditer(str2) >>> iterator <callable-iterator object at 0x7f28e96ba9d0> >>> for match in iterator: ... print match.span() ... (0, 2) (5, 6) (8, 10)
5、用pickle存储Python的原生对象(对象的序列化以及反序列化) pickle模块是能够让我们直接在文件中存储几乎任何Python对象的高级工具,也并不要求我们把字符串转换来转换去。
# 向文件中存储数据 >>> data = {'a':97, 'b':98, 'A':65, 'B':66} >>> datafile = open('data.txt','w') >>> import pickle >>> pickle.dump(data,datafile) >>> datafile.close() # 读取存储的数据 >>> datafile = open('data.txt') >>> data = pickle.load(datafile) >>> data {'a': 97, 'A': 65, 'B': 66, 'b': 98}
6、文件中打包二进制数据的存储与解析 struct模块能够构造并解析打包的二进制数据。
# 存储 >>> f = open('data.bin','wb') >>> import struct >>> bytes = struct.pack('>i4sh', 7, 'spam', 8) >>> bytes '\x00\x00\x00\x07spam\x00\x08' >>> f.write(bytes) >>> f.close() # 读取 >>> f = open('data.bin','rb') >>> data = f.read() >>> data '\x00\x00\x00\x07spam\x00\x08' >>> values = struct.unpack('>i4sh', data) >>> values (7, 'spam', 8)
7、进程模块工具
- Python的标准库中与进程和线程相关的模块和函数
模块名称 说明 os/sys 包含基本进程管理函数 subprocess Python基本库中多进程相关模块 signal Python基本库中信号相关模块 - 进程的操作示例
- os/sys模块 创建进程
- system函数 格式:system(command) 说明:此函数在新进程中执行command字符串命令。如果返回值为0,表示命令执行成功,否则表示失败。 示例:
>>> import os >>> print os.system('ls')
- exec 家族函数 exec家族中有8个类似的函数(execl, execle, execlp, execlpe, execv, execve, execvp, execvpe)。虽然用他们都可以创建进程,但是和system函数还是有些不同。system函数实际上是调用系统内置的命令行程序来执行系统命令,所以在命令结束之后会将控制权返回给Python进程。但是,所有的exec函数在执行命令之后,将会接管Python进程,而不会将控制权返回。换句话说,Python进程会在调用exec函数后终止。新生成的进程将会替换调用进程。这些函数都没有返回值,如果发生错误,将会触发OSError异常。 execl 函数 格式:execl(path, arg0, arg1, ...) 示例:
>>> import os >>> os.execl('/usr/bin/kate')
- sys.exit函数 exit函数是一种"温和"的终止进程方式,在程序退出之前会执行一些清理操作,同时将返回值给调用进程(一般是操作系统)。使用此返回值,系统可以判断程序是否是正常退出或者运行出了异常。 例子:
import sys try: filename = sys.argv[1] print filename except: print "Usage:", sys.argv[0], "filename" sys.exit(1)
- os.abort 函数 和exit函数不同的是,abort函数是一种"暴力"的退出方式,将会直接给进程发送终止信号(SIGABORT信号)。默认情况下,这将会终止进程,同时不会做相关的清理工作。需要注意的是,可以使用signal.signal()来为SIGABORT信号注册不同的信号处理函数,从而改变其默认行为。
- system函数 格式:system(command) 说明:此函数在新进程中执行command字符串命令。如果返回值为0,表示命令执行成功,否则表示失败。 示例:
- subprocess 模块 subprocess模块是作为进程管理的高级模块在2.4版本被引入的。subprocess可以调用外部的系统命令创建新的子进程,同时连接到子进程的input/output/error管道上,并得到子进程的返回值。这个模块可以用来替代一些旧模块的方法,如os.system, os.spawn*, os.popen*,popen2.*, commands.*等。subprocess模块中提供了一个类和两个使用函数来管理进程,下面将分别进行介绍。
- 使用Popen类管理进程 class Popen(args, bufsize=0, executable=None, stdin=None, stdout=None, stderr=None, preexec_fn=None, close_fds=False, shell=False, cwd=None, env=None, universal_newlines=False, startupinfo=None, creationflags=0) 其中,args参数为要执行的外部程序。其值可以是字符串或者序列。除此之外,其他的类参数都是有默认值,可以根据需要进行修改。
import subprocess pingP = subprocess.Popen(args='ping -c 4 www.sina.com', shell=True) pingP.wait() print pingP.pid print pingP.returncode
注:在Linux下,当shell为"False"时,Popen将调用os.execvp执行对应的程序。而shell为"True"时,如果命令为字符串,Popen直接调用系统shell来执行指定的程序。如果命令为一个序列,则其第一项是定义命令字符串,其他项为命令的附加参数。 - subprocess模块还提供了两个实用函数来直接调用外部系统命令:call()和check_all()。 call()会直接调用命令生成子进程,并且等待子进程结束,然后返回子进程的返回值。check_all()和call()函数的主要区别在于:如果返回值不为0,则触发CallProcessError异常。返回值保存在这个异常对象的returncode属性中。
import subprocess retcode = subprocess.call(['ls','-l']) #调用ls -l 命令
- 使用Popen类管理进程 class Popen(args, bufsize=0, executable=None, stdin=None, stdout=None, stderr=None, preexec_fn=None, close_fds=False, shell=False, cwd=None, env=None, universal_newlines=False, startupinfo=None, creationflags=0) 其中,args参数为要执行的外部程序。其值可以是字符串或者序列。除此之外,其他的类参数都是有默认值,可以根据需要进行修改。
- os/sys模块 创建进程
发表评论
-
python smtp 发邮件代码
2012-10-18 16:37 864#!/usr/bin/env python # -*- ... -
[Python]文件的创建与追加
2012-10-11 11:12 1044一、用Python创建一个新文件,内容是从0到9的整数, 每个 ... -
python import模块方法
2012-10-08 11:00 1059python包含子目录中的模块方法比较简单,关键是能够在sys ... -
pythoncomplete.vim
2012-09-28 10:34 891where is vim vim7.3中自带里自动补全 ... -
python 易混地带
2012-09-25 12:59 1084每门编程语言都有易混 ... -
python 特点
2012-09-25 12:56 12061、Python以模块文件的方式组织代码。 Python每个模 ... -
命名类、属性和方法
2012-09-10 16:50 795类名通常由大写字母打头。这是标准惯例,可以帮助你识别类, ... -
import 语句的模块顺序
2012-09-10 16:08 1581我们推荐所有的模块在 Python 模块的开头部分导入。 ... -
python 文件操作
2012-09-07 11:07 1065python中对文件、文件夹(文件操作函数)的操作需要 ... -
Python 函数参数
2012-09-05 11:25 6241. 函数参数 2. 函数引用 3. * Tuple 非关 ... -
Python 标准文件
2012-09-01 23:05 1043Python中, 只要程序一执行, 便可以访问三个标准文件:标 ... -
Python 二分查找
2012-08-29 00:00 854def bsearch(l = [], a = 0 ,b ... -
Python 浅拷贝 深拷贝
2012-08-09 21:25 870深拷贝:a -> b copy(a) ... -
Python Unicode
2012-08-08 21:10 811今天学习Python时,遇到一个问题,Python Non-A ... -
Python 字符串 Template
2012-08-05 16:43 722from string import Template ... -
Python 更新模型
2012-08-05 11:10 846更新模型,顾名思义就是对象在创建成功后,其值是否能够更新 p ... -
待解决问题
2012-08-04 20:25 7281. Python的循环引用 2. >>> ... -
Python __name__
2012-08-04 20:09 758看python程序是经常会碰到 if __name__ == ... -
Python Learning
2012-08-04 18:27 7541. # -*- coding: utf-8 -*- 推 ...
相关推荐
Python提供了大约200多个内置的标准模块,涵盖了Python运行时服务、文字模式匹配、操作系统接口、数学运算、对象永久保存、网络和Internet脚本和GUI构建等方面。 一、Python常用的内置标准模块 模块名 描述 sys...
8. `collections`模块:提供了许多高级数据结构,如有序字典、命名元组等,增强了Python内置数据结构的功能。 9. `threading`模块:实现了线程,用于多线程编程,提高程序执行效率。 10. `unittest`模块:提供了一...
在"python内置函数.pdf"这份文档中,主要介绍了四个关键部分:常用函数、内置类型转换函数、序列处理函数以及String模块。下面将详细阐述这些知识点。 1. **常用函数** - `abs(x)`:这个函数返回数字(包括复数)...
1. **内置模块**:Python在标准库中提供了一组内置模块,如`sys`用于系统交互,`os`用于操作系统接口,`math`提供了数学运算,`time`处理时间函数,以及`random`用于生成随机数等。 2. **数据结构模块**:`...
`pickle`是Python的一个内置模块,用于实现Python对象的序列化和反序列化。通过`pickle`,我们可以将Python中的各种数据结构(如列表、字典、元组等)转换成一个字节流(bytes),这样就可以方便地在网络上传输或者...
在Python编程语言中,内置函数是不需要导入任何模块就可以直接使用的函数,它们...以上仅为Python内置函数的一部分知识点,Python的内置函数和模块非常丰富,为程序员提供了强大的工具库,使得编写程序更加高效和方便。
Python内置模块是Python标准库的一部分,它们提供了许多预先编写的函数和类,使得开发者能够方便地进行各种操作。本文将详细介绍几个常用的内置模块,包括random、collections和queue。 首先,让我们来看看`random`...
Python还有内置模块,如`os`、`sys`、`datetime`等,它们提供操作系统接口、系统相关信息和日期时间操作等核心功能。这些模块在Python安装时就已经包含,无需额外安装。 模块导入机制遵循以下规则: - 当第一次导入...
这个名为"python基础模块及内置函数.zip"的压缩包显然聚焦于介绍Python的核心特性,包括内置函数和常用的基础模块。让我们逐一深入探讨这些主题。 首先,我们来看**内置函数**。Python的内置函数是语言的一部分,...
**Dateutil** 是一个增强Python内置`datetime`模块功能的库。它提供了解析日期和时间的高级功能,如解析非标准格式的日期字符串,处理各种时区,以及计算日期间隔。Dateutil可以帮助开发者处理复杂的时间序列数据,...
以下是一些关键的Python内置函数及其用法: 1. `print()`: 这个函数用于将数据输出到标准输出设备,如显示器或打印机。可以接受多个参数,用逗号分隔,它们会被自动转换为字符串并连接在一起。 2. `len()`: 返回...
Python的logging模块提供了通用的日志系统,可以方便第三方模块或者是应用使用。这个模块提供不同的日志级别,并可以采用不同的方式记录日志,比如文件,HTTP GET/POST,SMTP,Socket等,甚至可以自己实现具体的日志...
例如,要使用内置的数学模块: ```python import math print(math.sqrt(16)) # 输出4,因为sqrt是求平方根的函数 ``` 7. 加强练习: 练习是提升编程技能的关键。你可以尝试创建一个复杂的类结构,包含继承关系...
* operator: operator提供了访问python内置的操作和解析器提供的特殊方法,例如 x+y 为 add(x,y),x+=y为iadd(x,y),a % b 为mod(a,b)等等。 * 其他:abc,contextlib,functools。 4) string 和 text ...
之后,如果再次导入该模块,Python会检查是否已存在名为该模块的全局变量,如果是,则直接使用缓存的模块对象,不会重新执行代码。 三、Python标准库模块 Python提供了大量的内置模块,这些模块覆盖了网络通信、...
OS 模块是 Python 的一个内置模块,提供了多数操作系统的功能接口函数。当 OS 模块被导入后,它会自适应于不同的操作系统平台,根据不同的平台进行相应的操作。在 Python 编程时,经常和文件、目录打交道,这是就离...
在Python的学习过程中,思维导图可以帮助我们梳理语言的各个组成部分,如基础语法、数据类型、控制流、函数、模块、面向对象编程等。 1. **基础语法**:Python的基础语法包括变量定义、注释、缩进规则等。Python以...
Python是一种解释型、面向对象的编程语言,它支持多范式编程,包含动态类型系统和垃圾回收功能。它广泛应用于科学计算、数据分析、人工智能、网络开发等领域。 ### 函数、模块和帮助 #### 获取帮助 - `help()`: ...
time 模块是 Python 的一个内置模块,它提供了多种方式来处理时间。time 模块的主要功能是提供 Unix Timestamp,基于 1970 年 1 月 1 日 00:00:00 开始按秒计算的偏移量。因此,time 模块所能表述的日期范围被限定在...