1.lambda lambda其实就是一条语句,lambda(x):body。x是lambda函数的参数,参数可以有任意多个(包括可选参数);body是函数体,只能是一个表达式,并且直接返回该表达式的值。
>>>f=lambda x:x+1
>>>f(2)
3
>>>(lambda x,y:x+y)(2,3)
5

2.filter filter(func, list)接受两个参数:一个函数func和一个列表list,返回一个列表。函数func只能有一个参数。filter的功能:列表中所有元素作为参数传递给函数,返回可以另func返回真的元素的列表
>>>l=['abc','acd','1245','ddad','aaa']
>>> def func(s):
    return s.startswith('a')
>>>filter(func, l)
['abc','acd','aaa']

>>> li = [1,2,3,4]

>>> filter(lambda x: x>2, li)

[3, 4]

2.1 循环过程中根据条件返回

>>> {x for x in 'abracadabra' if x not in 'abc'}

set(['r', 'd'])

3.zip  zip函数接受任意多个序列作为参数,将所有序列按相同的索引组合成一个元素是各个序列合并成的tuple的新序列,新的序列的长度以参数中最短的序列为准。另外(*)操作符与zip函数配合可以实现与zip相反的功能,即将合并的序列拆成多个tuple
>>>x=[1,2,3]
>>>y=['a','b','c']
>>>zip(x,y)
[(1,'a'),(2,'b'),(3,'c')]
>>>zip(*zip(x,y))
[(1,2,3),('a','b','c')]

4.map为操作list,返回list,绑定的函数为修改list中每一个值的函数
>>> list=[1,2,3]
>>> map(lambda x : x*2,list)
>>> [2, 4, 6]

5.reduce为逐次操作list里的每项,接收的参数为 2个,最后返回的为一个结果
>>> def func(x,y):  
>>>     return x+y
>>> reduce(func,(1,2,3)) 
>>> 6

6.sorted字典排序

>>> import operator
>>> x = {1:2, 3:4, 4:3, 2:1, 0:0}
>>> sorted(x.iteritems(), key=operator.itemgetter(1), reverse=True)
[(3, 4), (4, 3), (1, 2), (2, 1), (0, 0)]

>>> sorted(x.iteritems(), key=lambda x: x[1], reverse=False)
[(0, 0), (2, 1), (1, 2), (4, 3), (3, 4)]

7.列表字典排序

>>> li = [{'name':'wang', 'age':30}, {'name':'zhang', 'age':20}, {'name':'li', 'age':25}]
>>> sorted(li, key=lambda x : x['name'], reverse=False)
[{'age': 25, 'name': 'li'}, {'age': 30, 'name': 'wang'}, {'age': 20, 'name': 'zhang'}]

>>> sorted(li, key=operator.itemgetter('name'), reverse=True)
[{'age': 20, 'name': 'zhang'}, {'age': 30, 'name': 'wang'}, {'age': 25, 'name': 'li'}]

8.翻转字符串

>>> s = "abcd"

>>> s[::-1]

'dcba'

>>> "".join(sorted(list(s),reverse=True))

'dcba'

9.元祖(tuple)、字典(dict)之间转换

>>> t = ((1,"a"),(2,"b"))

>>> dict(t) #元祖转字典

{1: 'a', 2: 'b'}

>>> d = dict(t)

>>> d.items() #字典转元祖

[(1, 'a'), (2, 'b')]

>>> t = (1,"a")

>>> dict([t]) #单个元祖转字典

{1: 'a'}

>>> d = dict([t])

>>> d.popitem()

(1, 'a')

>>> d.items()[0] #单个字典转元祖

(1, 'a')

增加键值名称

>>> li = [{1:"a"},{2:"b"}]

>>> [dict(zip(("key","value"), obj.items()[0])) for obj in li]

[{'value': 'a', 'key': 1}, {'value': 'b', 'key': 2}]

>>> map(lambda x: dict(zip(("key","value"), x.items()[0])),li)

[{'value': 'a', 'key': 1}, {'value': 'b', 'key': 2}]

>>> li2 = [{'value': 'a', 'key': 1}, {'value': 'b', 'key': 2}]

>>> [{obj["key"]:obj["value"]} for obj in li2]

[{1: 'a'}, {2: 'b'}]

单行语句增加属性值

>>> li = [{"o":'A'},{"o":'B'},{"o":'C'}]
>>> [obj.update({"i":i+1}) or obj for i, obj in enumerate(li)]   # 暂时未找到字典对象设置属性值后返回该对象的函数,所以用or来取巧实现该功能
[{'i': 1, 'o': 'A'}, {'i': 2, 'o': 'B'}, {'i': 3, 'o': 'C'}]

列表内对象值分组

>>> li = [{"k":"1", "v":"v1"},{"k":"2", "v":"v2"},{"k":"1", "v":"v3"}]

>>> keys = set(map(lambda x:x["k"], li))  # 取出key值

>>> newlist = [{"k":x, "v":[y["v"] for y in li if y["k"]==x]} for x in keys]

>>> print newlist

[{'k': '1', 'v': ['v1', 'v3']}, {'k': '2', 'v': ['v2']}]

10. 打印一个对象的所有属性和值

for property, value in vars(theObject).iteritems():

print property, ": ", value

这个做法其实就是 theObject.__dict__ , 也就是 vars(obj) 其实就是返回了 o.__dict__

11.列表分页

>>> mylist = [1, 2, 3, 4, 5, 6, 7, 8, 9]

>>> print [mylist[i:i+4] for i in range(0, len(mylist), 4)]

[[1, 2, 3, 4], [5, 6, 7, 8], [9]]

12.列表步长

语法:L[start:stop:step]

mylist = [1,2,3,4,5,6,7,8,9,10]

for i in mylist[::2]:

print i,

# prints 1 3 5 7 9

for i in mylist[1::2]:

print i,

# prints 2 4 6 8 10

>>> range(1, 10, 2)

[1, 3, 5, 7, 9]

12. python字符串格式化,2.7之后增加新的字符串格式化方法format, 之前都是用%符号

>>> '{},{}'.format('aa','bb')

'aa,bb'

>>> "{0},{2},{1}".format(1,2,3)

'1,3,2'

>>> "{0},{2},{1},{str}".format(1,2,3,str="string")

'1,3,2,string'

>>> '{0[0]},{0[1]}'.format(['aa',"bb"])

'aa,bb'

>>> '{:>10}'.format('12')  # 字符串左边空格填充

'        12'

>>> '{:a<10}'.format('12')  # 字符串右边字母"a"填充

'12aaaaaaaa'

>>> '{:.2f}'.format(321.33345)  # 浮点类型

'321.33'

>>> '{:b}'.format(17)  # 格式化为二进制

'10001'

>>> '{:x}'.format(17)  # 十六进制

'11'

>>> "&nbsp;" * 4  # 复制多个字符串

'&nbsp;&nbsp;&nbsp;&nbsp;'

13. 随机数

随机选取字符串:

>>> import random

>>> random.choice ( ['apple', 'pear', 'peach', 'orange', 'lemon'] )

'lemon'

洗牌:

>>> items = [1, 2, 3, 4, 5, 6]

>>> random.shuffle(items)

>>> items

[3, 2, 5, 6, 4, 1]

多个字符中选取特定数量的字符:

>>> random.sample('abcdefghij',3)

['a', 'd', 'b']

随机整数:

>>> random.randint(0,99)

21

随机选取0到100间的偶数:

>>> random.randrange(0, 101, 2)

42

14.动态对象操作

14.1 动态执行表达式

>>> x = 1
>>> print eval('x+1')    # 该函数将字符串str当成有效Python表达式来求值,并返回计算结果,但不能动态更新值,如:eval("x=2")会报错。
2

14.2 动态获取更新变量值

>>> d = {"name":"wei"}
>>> d2 = {"age":20}
>>> vars()['d']
{'name': 'wei'}
>>> vars()['d'].update(d2)  # 如果全局变量使用globals()
>>> print d
{'age': 20, 'name': 'wei'}
>>> d3 = {"phone":"139"}
>>> exec("d.update(d3)")
>>> print d
{'phone': '139', 'age': 20, 'name': 'wei'}
>>> print vars()["d"]
{'phone': '139', 'age': 20, 'name': 'wei'}
>>> print exec("d")  # exec语句将字符串str当成有效Python代码来执行,但不返回值。
File "<input>", line 1
print exec("d")
^
SyntaxError: invalid syntax

14.3 动态获取设置属性值

u = User.objects.get(id=1)
name = getattr(u, "username", "wei")  # 第三个参数未默认值
kwargs = {"username": name}
User.objects.filter(id=1).update(**kwargs)
setattr(u, "username", "wei")

15.集合操作

>>> s = set("ab")
>>> s2 = set("abc")
>>> s & s2 # or s.intersection(s2) 交集
set(['a', 'b'])
>>> s | s2 # or s.union(s2) 并集,相当于两个集合的和
set(['a', 'c', 'b'])
>>> s2 - s # or s2.difference(s) 差集,如果s-s2 则返回空集合
set(['c'])
>>> s ^ s2 # or s.symmetric_difference(s2) 对称差集(项在s或s2中,但不会同时出现在二者中)
set(['c'])
s.issubset(s2) or s <= s2 :检测s是否是s2的子集,是则返回True,否则返回False
s2.issuperset(s) or s2 >= s:检测s2是否是s的超集,是则返回True,否则返回False

s.update(s2) or s |= s2 # 返回增加了 set “s2”中元素后的 set “s”
s.intersection_update(s2) or s &= s2 # 返回只保留含有 set “s2”中元素的 set “s”
s.difference_update(s2) or s -= s2 # 返回删除了 set “s2”中含有的元素后的 set “s”
s.symmetric_difference_update(s2) or s ^= s2 # 返回含有 set “s2”或者 set “s”中有而不是两者都有的元素的 set “s”
s.add(s2) # 向 set “s”中增加元素 s2
s.remove(s2) # 从 set “s”中删除元素 s2, 如果不存在则引发 KeyError
s.discard(s2) # 如果在 set “s”中存在元素 s2, 则删除
s.copy() # 返回 set “s”的一个浅复制

16.返回列表中第一个匹配的值
>>> first_or_default = next((x for x in [{"id":1},{"id":2},{"id":1, "name":"wang"}] if x["id"] == 1), None)
>>> print first_or_default
{'id': 1}

其它语音动态设置示例:http://rosettacode.org/wiki/Dynamic_variable_names#Pythonpython 使用技巧锦集:http://www.oschina.net/translate/thirty-python-language-features-and-tricks-you-may-not-know

Python常用函数笔记的更多相关文章

  1. Python常用函数记录

    Python常用函数/方法记录 一. Python的random模块: 导入模块: import random 1. random()方法: 如上如可知该函数返回一个[0,1)(左闭右开)的一个随机的 ...

  2. STL之vector常用函数笔记

    STL之vector常用函数笔记 学会一些常用的vector就足够去刷acm的题了 ps:for(auto x:b) cout<<x<<" ";是基于范围的 ...

  3. Python常用函数、方法、模块记录

    常用函数: 1.pow():乘方 2.abs():绝对值 3.round():四舍五入 4.int():转换为整数 5.input():键盘输入(会根据用户的输入来做类型的转换) raw_input( ...

  4. python常用函数年初大总结

    1.常用内置函数:(不用import就可以直接使用) help(obj) 在线帮助, obj可是任何类型 callable(obj) 查看一个obj是不是可以像函数一样调用 repr(obj) 得到o ...

  5. python常用函数总结

    原文地址https://www.cnblogs.com/nice107/p/8118876.html 我们在学习python的时候,接触最多的往往则是那些函数,对于python函数,在这里为大家总结归 ...

  6. 超级干货,python常用函数大总结

    我们在学习python的时候,接触最多的往往则是那些函数,对于python函数,在这里为大家总结归纳了这些,如果有缺漏,还请及时留言指正哦! 话不多说,干货来袭! 1.常用内置函数:(不用import ...

  7. python常用函数库收集。

    学习过Python都知道python中有很多库.python本身就是万能胶水,众多强大的库/模块正是它的优势. 收集一些Python常用的函数库,方便大家选择要学习的库,也方便自己学习收集,熟悉运用好 ...

  8. python常用函数拾零

    Python常用内置函数总结: 整理过程中参考了runoob网站中python内置函数的相关知识点,特此鸣谢!! 原文地址:http://www.runoob.com/python/python-bu ...

  9. python 常用函数集合

    1.常用函数     round() :  四舍五入         参数1:要处理的小数         参数2:可选,如果不加,就是不要小数,如果加,就是保留几位小数     abs() :绝对值 ...

随机推荐

  1. URL和URI的区别与联系

    转自:http://win7452.blog.51cto.com/147513/45741 今天在看STRUTS配置的时候,发现一个问题,就是在看配置文件的时候,有时出现URL有时又是URI, 让我心 ...

  2. N个数的排列算法

    #include <stdio.h> int n = 0; //交换两个数void swap(int *a, int *b) { int m; m = *a; *a = *b; *b = ...

  3. loj 1155(最大流)

    题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=26869 思路:题目还是比较水的,由于点也有容量,则必须拆点,然后跑 ...

  4. loj 1300( 边双联通 + 判奇圈 )

    题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=27010 思路:首先Tarjan标记桥,然后对于dfs遍历整个图,我 ...

  5. C++primer学习笔记(三)——Chapter 5

    5.1   Simple Statements 1.记得每个语句后面加上”;”不过现在编译器都有实时编译,一般都不会忘记的, 2.空语句 (1)就是啥都没有.只有一个“:” (2)还是有很多用处的,例 ...

  6. SQL事务用法begin tran,commit tran和rollback tran的用法

    Sql Server 2005/2008中提供了begin tran,commit tran和rollback tran来使用事务. begin tran表示开始事务, commit tran表示提交 ...

  7. AsyncTask下载JSON

    public class HttpUtils { // 从网络url上下载字符串 public static String getHttpStr(String url) { HttpClient ht ...

  8. android上传文件到服务器

    package com.spring.sky.image.upload.network; import java.io.DataOutputStream; import java.io.File; i ...

  9. poj 1115 Lifting the Stone 计算多边形的中心

    Lifting the Stone Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u S ...

  10. 深入理解DIP、IoC、DI以及IoC容器(转)

    深入理解DIP.IoC.DI以及IoC容器 摘要 面向对象设计(OOD)有助于我们开发出高性能.易扩展以及易复用的程序.其中,OOD有一个重要的思想那就是依赖倒置原则(DIP),并由此引申出IoC.D ...