$Python常用内置函数典型用法
Python中有许多功能丰富的内置函数,本文基于Python 2.7,就常用的一些函数的典型用法做一些积累,不断更新中。
sorted函数的三种用法
# coding:utf-8
# sorted函数的三种用法
from operator import itemgetter
data1 = [{'aa':22,'bb':11},{'aa':12,'cc':23},{'aa':67,'dd':103}]
data2 = [{'age':18,'name':'Tom'},{'age':10,'name':'Tim'},{'age':30,'name':'John'},{'age':18,'name':'Amy'}]
def sort1():
# 对data1依据'aa'字段值的大小从小打到排序
ret = sorted(data1,key = lambda item:item['aa']) # 注:如果这里的key写'bb'或'cc',会报KeyError,因为这两个属性并不是每个元素都有的
print ret
# 输出:
'''
[{'aa': 12, 'cc': 23}, {'aa': 22, 'bb': 11}, {'aa': 67, 'dd': 103}]
'''
def sort2():
# 对data1依据'aa'字段值的大小从小打到排序
ret = sorted(data1,cmp = lambda x,y:cmp(x['aa'],y['aa']))
print ret
# 输出:
'''
[{'aa': 12, 'cc': 23}, {'aa': 22, 'bb': 11}, {'aa': 67, 'dd': 103}]
'''
def sort3():
# 使用itemgetter对data1依据'aa'字段值的大小从小打到排序
ret = sorted(data1,key = itemgetter('aa'))
print ret
# 输出:
'''
[{'aa': 12, 'cc': 23}, {'aa': 22, 'bb': 11}, {'aa': 67, 'dd': 103}]
'''
def sort4():
# 对data2进行排序,先按照'age'从小到大排序,'age'相同的情况下,再按照'name'排序
ret = sorted(data2,key = itemgetter('age','name'))
print ret
# 输出:
'''
[{'age': 10, 'name': 'Tim'}, {'age': 18, 'name': 'Amy'}, {'age': 18, 'name': 'Tom'}, {'age': 30, 'name': 'John'}]
'''
执行命令行命令的三种方式
# coding:utf-8
# 执行命令行命令的三种方式
import os
import commands
command = 'ls -al /root'
def method1():
'''
方式1
'''
os.system(command)
# 执行结果:返回执行状态码
def method2():
'''
方式2
'''
out1 = os.popen(command)
print out1.read()
# 输出:执行结果字符串
def method3():
'''
方式3
'''
(status,out) = commands.getstatusoutput(command)
# 输出:status是执行状态码,out是执行结果字符串
zip函数的用法
Docstring:
zip(seq1 [, seq2 [...]]) -> [(seq1[0], seq2[0] ...), (...)]
Return a list of tuples, where each tuple contains the i-th element
from each of the argument sequences. The returned list is truncated
in length to the length of the shortest argument sequence.
先来看看zip函数的文档,从文档中可以看出,zip函数接收1个或多个序列作为参数,返回一个由元组组成的列表。
结果列表的第i个元素是seq1~seqn的第i个元素组成的元组。
结果列表的长度等于seq1~seqn中最短的序列的长度。
一段测试代码如下:
# coding:utf-8
def main():
a = '1234'
b = [4,6,7]
print zip()
# 输出:[]
print zip(a)
# 输出:[('1',), ('2',), ('3',), ('4',)]
print zip(a,a)
# 输出:[('1', '1'), ('2', '2'), ('3', '3'), ('4', '4')]
print zip(a,[])
# 输出:[]
print zip(a,b)
# 输出:[('1', 4), ('2', 6), ('3', 7)]
if __name__ == '__main__':
main()
map函数的用法
map函数是一个高阶函数,支持传入一个函数作为参数。先来看它的文档是怎么说的:
Docstring:
map(function, sequence[, sequence, ...]) -> list
Return a list of the results of applying the function to the items of
the argument sequence(s). If more than one sequence is given, the
function is called with an argument list consisting of the corresponding
item of each sequence, substituting None for missing values when not all
sequences have the same length. If the function is None, return a list of
the items of the sequence (or a list of tuples if more than one sequence).
从map函数的文档中可以看出,该函数的第一个参数为一个函数对象,后面可以跟一个或多个序列,函数的返回值是一个list.
对比zip函数的用法,可以发现其实map函数就是一个增强版的zip函数,与zip函数不同的是,map函数支持传入一个函数参数来处理序列。
如果第一个函数参数不为None,那么返回的结果list的第i个元素,是将该函数作用于每个序列的第i个元素的结果。如果传入的序列的长度不都是相同的,那么结果list的某些元素将会是None.
如果第一个函数参数为None,那么返回的的结果list的第i个元素,是每个序列第i个元素组成的n元组(n为序列的个数),如果每个序列的长度不都是相同的,那么结果list的某些元素将是None.
下面通过一段程序来看map函数的实际用法:
# coding:utf-8
def main():
a = [1,2,3,4]
b = [3,5,9]
c = [8,2,3]
print map(None,a,b,c)
# 输出:[(1, 3, 8), (2, 5, 2), (3, 9, 3), (4, None, None)]
print map(lambda x : x ** 2,a)
# 输出:[1, 4, 9, 16]
# print map(lambda x,y : x + y,a)
# 输出:TypeError <lambda>() takes exactly 2 arguments (1 given)
print map(lambda x,y : x + y,b,c)
# 输出:[11, 7, 12]
# print map(lambda x,y,z : x + y + z,a,b,c)
# 输出:TypeError: unsupported operand type(s) for +: 'int' and 'NoneType'
print map(lambda x,y : x + y if x is not None and y is not None else None,a,b)
# 输出:[4, 7, 12, None]
if __name__ == '__main__':
main()
reduce函数的用法
先看函数文档:
Docstring:
reduce(function, sequence[, initial]) -> value
Apply a function of two arguments cumulatively to the items of a sequence,
from left to right, so as to reduce the sequence to a single value.
For example, reduce(lambda x, y: x+y, [1, 2, 3, 4, 5]) calculates
((((1+2)+3)+4)+5). If initial is present, it is placed before the items
of the sequence in the calculation, and serves as a default when the
sequence is empty.
reduce函数接收三个参数:function,seq,init,其中前两个是必选参数,最后一个为可选参数。
reduce函数做了这样一件事情:从左到右遍历seq,将seq[0]和seq[1]传入函数function进行运算(function为一个接收两个参数的函数),得到一个结果值,然后将这个结果值再和seq[2]传入fucntion进行运算再得到一个新的结果值...以此类推。最终得到一个值,就是该函数的返回值。
如果传入了init,那么init和seq[0]会作为第一次传入funciton的参数,如果seq为空,init也会作为reduce的返回值返回。
用法示例如下:
# coding:utf-8
def main():
lst = [1,2,3]
f = lambda x,y:x*y
print reduce(f,lst)
# 输出:6
print reduce(f,lst,-1)
# 输出:-6
print reduce(f,[],-2)
# 输出:-2
if __name__ == '__main__':
main()
base64编解码
# coding:utf-8
# 测试base64编解码
import base64
def main():
s = '123abc'
# 编码
print base64.b64encode(s)
# 输出:MTIzYWJj
# 解码
print base64.b64decode('MTIzYWJj')
# 输出:123abc
if __name__ == '__main__':
main()
随机推荐
- JVM内存简析
1.程序计数器: 这是一块较小的内存空间,它的作用可以看作是当前线程所执行的字节码的行号指示器,线程私有. 2.Java虚拟机栈: 它是Java方法执行的内存模型,每一个方法被调用到执行完成的过程,就 ...
- $("#btn").click(function(){ });只有在页面加载的时候才会有效触发
例: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title& ...
- jqGrid排序的两种实现方式
实现方案一客户端实现排序: jqGrid属性 loadonce:true时,所有数据加载在客户端,点击列标题由jqGrid在客户端自动排序,不再从服务器取值. 参考文件:ccMxCxTjCc.js j ...
- poj_3628 动态规划
题目大意 有N个数字,大小为a[i], 给定一个数S,用这N个数中的某些数加起来使得结果sum>= S,且sum-S最小,求该最小的sum-S值. 题目分析 题意中可知,这N个数字的和肯定大于S ...
- 【BZOJ5083】普及 单调栈+二分+RMQ
[BZOJ5083]普及 Description 有一个长度为n的字符串,每一位只会是p或j.你需要取出一个子串S(从左到右或从右到左一个一个取出),使得 不管是从左往右还是从右往左取,都保证每时每刻 ...
- Python--进阶处理7
# ====================第七章:函数========================= # 为了能让一个函数接受任意数量的位置参数,可以使用一个* 参数# 为了接受任意数量的关键字 ...
- C#批量入库
public static void BulkCopyToDB(DataTable dt, string conn, string tableName, out string msg) { msg = ...
- 20165330 2017-2018-2 《Java程序设计》第5周学习总结
课本知识总结 第七章 内部类与异常类 内部类:类的一种成员 外嵌类:包含内部类的类称为内部类的外嵌类 二者关系: 内部类的外嵌类的成员变量在内部类中仍然有效,内部类中的方法也可以调用外嵌类中的方法. ...
- Python进阶知识
装饰器 迭代器 生成器 mixins 元编程 描述符 量化领域常用 列表推导式 字典推导式 高阶函数 lambda函数 三目表达式
- Guess Your Way Out! II---cf 558D (区间覆盖,c++STL map 的使用)
题目链接:http://codeforces.com/contest/558/problem/D 题意就是有一个二叉树高度为 h ,人站在根节点上,现在要走出去,出口在叶子节点上,有 q 条信息,每条 ...