一、collection系列
1、计数器(counter)
collection是对字典中重复字符出现的次数,其具备字典的所有功能加自己的功能相对与包含字典。
举例:
 #!/usr/bin/env  python
 # --*--coding:utf-8 --*--
 import collections
 c = collections.Counter("sdsasdsa") 
 print c

输出结果是:

 Counter({'s': 4, 'a': 2, 'd': 2})

如果说提取里面的值就需要用到

 b = collections.Counter('aswedswedswedswed')
 print b
 b.update(c) #把c添加到b里面
 print b

输出结果是:

 Counter({'s': 4, 'a': 2, 'd': 2})
 Counter({'s': 4, 'e': 4, 'd': 4, 'w': 4, 'a': 1})
 Counter({'s': 8, 'd': 6, 'e': 4, 'w': 4, 'a': 3})
 import collections
 c = collections.Counter("sdsasdsa") #打印出后面重复的字符串
 print c
 print c.most_common(3) #显示前几个

输出结果是:

 Counter({'s': 4, 'a': 2, 'd': 2})
 [('s', 4), ('a', 2), ('d', 2)]
 print sorted(b) #按顺序打印元素
 print b

输出结果是:

 Counter({'s': 4, 'e': 4, 'd': 4, 'w': 4, 'a': 1})
 ['a', 'd', 'e', 's', 'w']
2、默认字典(defaultdict) 
有如下值集合 [11,22,33,44,55,66,77,88,99,90...],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中。
即: {'k1': 大于66 , 'k2': 小于66}
 from collections import defaultdict
 values = [11, 22, 33,44,55,66,77,88,99,90]
 my_dict = defaultdict(list)
 for value in  values:
     if value>66:
          my_dict['k1'].append(value)
     else:
          my_dict['k2'].append(value)
 print my_dict

输出结果是:

defaultdict(<type 'list'>, {'k2': [11, 22, 33, 44, 55, 66], 'k1': [77, 88, 99, 90]})

3、有序字典(orderedDict )

记住了字典元素的添加顺序,进行排序
 from collections import OrderedDict
 a = {'a':1 , 'b':2 , 'c': 3}
 print OrderedDict(sorted(a.items(), key=lambda t: t[1]))
 print OrderedDict(sorted(a.items(), key=lambda t: len(t[0])))
 print OrderedDict(sorted(a.items(), key=lambda t: t[1]))

输出结果是:

 OrderedDict([('a', 1), ('b', 2), ('c', 3)])
 OrderedDict([('a', 1), ('c', 3), ('b', 2)])
 OrderedDict([('a', 1), ('b', 2), ('c', 3)])

4、可命名元组(namedtuple)

根据nametuple可以创建一个包含tuple所有功能以及其他功能的类型,可命名元组
 Mytuple = collections.namedtuple('Mytuple',['x', 'y'])    #新建元组
 old = Mytuple(1, 2)
 print old
 new = Mytuple(1,2)
 print new

输出结果是:

 Mytuple(x=1, y=2)
 Mytuple(x=1, y=2)

5、双向队列(deque)

#线程安全的双向队列
 q = collections.deque() #加双向队列
 q.append(11)    #添加队列
 q.append(12)
 q.append(13)
 print q
 print q.popleft() #左边取值
 print q.pop() #右边取值
#单向队列,队列FIFO ,栈,弹夹
 import Queue    #模块
 q = Queue.Queue()
 q.put(1) #价值
 q.put(2)
 q.put(3)
 print q.get(1)    #取值

#vars() = 当前模块的所有变量

 # print vars()
 # {'__builtins__': <module '__builtin__' (built-in)>, '__file__': 'D:/s11day2/s11day2/coll.py', '__package__': None, 'collections': <module 'collections' from 'D:\Python27\Lib\collections.pyc'>, '__name__': '__main__', '__doc__': None}
二、内置函数

内置函数就是,python内部已经定义好的函数

all(值) #当值都是真的时候,返回真,否则返回假
any()   #只要有一个真,全为真,否则为假
 1 >>> li = ['as', 'aa', '']
 2 >>> any(li)
 3 True
 4 >>> all(li)
 5 False
 6 >>> li = ['as', 'aa', 'as']
 7 >>> all(li)
 8 True
 9 >>> any(li)
 True
 >>> li = ['', '', '']
 >>> any(li)
 False
 for k,v in enumerate(li, 起始值)
     print k,v
三、自定义函数

自己写好的函数,在用的时候调用,不用的时候不执行

#邮件报警
 1 import smtplib
 2 from email.mime.text import MIMEText
 3 from email.utils import formataddr
 4 def email(message): #收件人可以是一个列表多个参数receiver
 5     msg = MIMEText(message, 'plain', 'utf-8')
 6     msg['From'] = formataddr(["发件者姓名",'发件邮箱'])
 7     msg['To'] = formataddr(["收件者姓名",'收件箱'])
 8     msg['Subject'] = "主题"
 9     server = smtplib.SMTP("smtp.qq.com", 25)
     server.login("发件邮箱", "密码")
     server.sendmail('发件邮箱', ['收件箱',], msg.as_string())
     server.quit()
#收件人可以是一个列表多个参数receiver

#在加一个for循环

 1 if __name__ == '__main__':
 2     cpu = 90
 3     disk = 100
 4     ram = 50
 5     for i in range(1):
 6         if cpu > 80:
 7             alert = u"CPU报警"
 8             email(alert)
 9         if disk > 120:
             alert = u"disk报警"
             emial(alert)
         if ram > 20:
             alert = u"内存报警"
             email(alert)
四、动态参数

图解:

 1 >>> def func(*arg):
 2 ...     print arg
 3 ...
 4 >>> func()
 5 ()
 6 >>> func(1)
 7 (1,)
 8 >>> func(1,2)
 9 (1, 2)
 >>> func(1,2,3)
 (1, 2, 3)
 >>> li = (11,22,33,44,55,66)
 >>> func(li)
 ((11, 22, 33, 44, 55, 66),)
 >>> func(*li)
 (11, 22, 33, 44, 55, 66)

1、接受多个参数

2、内部自动构造元组
3、序列,*,避免内部构造元组
加一个*内部构造是元组,两个**kwargs是构造字典,传入的时候要func(k1=123,k2=124),传入字典
 1 func(**dic)
 2 >>> def func(**kwargs):
 3 ...     print kwargs
 4 ...
 5 >>> func()
 6 {}
 7 >>> func(123)
 8 Traceback (most recent call last):
 9   File "<stdin>", line 1, in <module>
 TypeError: func() takes exactly 0 arguments (1 given)
 >>> func(k1=123,k2=234)
 {'k2': 234, 'k1': 123}
 >>> ls = {'k1':233, 'k2':345}
 >>> func(**ls)
 {'k2': 345, 'k1': 233}

两个动态函数结合

python之路:进阶 二的更多相关文章

  1. 第十三章:Python の 网络编程进阶(二)

    本課主題 SQLAlchemy - Core SQLAlchemy - ORM Paramiko 介紹和操作 上下文操作应用 初探堡垒机 SQLAlchemy - Core 连接 URL 通过 cre ...

  2. Python之路Day19-Django(二)

    本节内容概要: 一.路由系统URL 二.视图 三.模板 四.ORM操作 问题1:Django请求生命周期 -> URL对应关系(匹配) -> 视图函数 -> 返回用户字符串 -> ...

  3. Python之路Day16--JavaScript(二)

    本节内容: 1.上节内容回顾 2.JavaScript补充 $$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$ 一.上节内容回顾 1.作业问题: a.页面布局不好 ...

  4. Python编程-函数进阶二

    一.生成器补充 1.什么是生成器? 可以理解为一种数据类型,这种数据类型自动实现了迭代器协议(其他的数据类型需要调用自己内置的__iter__方法),所以生成器就是可迭代对象. 2.生成器分类 (1) ...

  5. 百万年薪python之路 -- 模块二

    1. 序列化模块 什么是序列化呢? 序列化的本质就是将一种数据结构(如字典.列表)等转换成一个特殊的序列(字符串或者bytes)的过程就叫做序列化. 为什么要有序列化模块? 如果你写入文件中的字符串是 ...

  6. python之路十二

    本节内容 数据库介绍 mysql 数据库安装使用 mysql管理 mysql 数据类型 常用mysql命令 创建数据库 外键 增删改查表 权限 事务 索引 python 操作mysql ORM sql ...

  7. Python之路(二)

    (1)python的内置函数(BIF) python3中内置了70多个BIF,常用的几个有: list():创建一个新的空列表. range():输入次数参数,返回一个迭代固定次数的迭代器. enum ...

  8. python之路----进程二

    守护进程 会随着主进程的结束而结束. 主进程创建守护进程 其一:守护进程会在主进程代码执行结束后就终止 其二:守护进程内无法再开启子进程,否则抛出异常:AssertionError: daemonic ...

  9. 小白学习python之路(二):安装开发工具

    引言 上一章我们安装配置了python3.7,这一章我们安装python的开发工具,我用的pycharm2019 安装 工具连接:https://u20538204.ctfile.com/fs/205 ...

  10. Python之路【第十七篇】:Django【进阶篇 】

    Python之路[第十七篇]:Django[进阶篇 ]   Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接 ...

随机推荐

  1. Storm官方帮助手册翻译(上)

    Storm作为当前最流行的实时计算框架,自Twitter将其开源后就一直备受关注.由于其具有先天的稳定性以及便捷性,目前被许多大公司所采用,国外像雅虎.雅虎日本.Twitter.OOYALA.Spot ...

  2. 利用文本编辑器输入课堂上练习的Hello.java,并在JDK环境下编译和运行。

  3. flash Ane

    1.ANE简介 Adobe AIR Native Extension,Adobe AIR的本地扩展,简称ANE.什么叫本地扩展?因为Adobe AIR是跨平台的一个运行时,可以在Windows,Mac ...

  4. IBM Mq Spring JMS 的xml配置

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...

  5. centos精简系统 源码安装客户端git

    CentOS的yum源中git版本比较低,需要最新版本git,只能自己编译安装,现在记录下编译安装的内容,留给自己备忘. 对于精简型的centos系统,会缺少很多依赖包和插件,要源码安装客户端git, ...

  6. File类与FileInfo类区别

    ile类是静态的,FileInfo不是静态的也没有静态的方法,仅可用于实例化的对象.FileInfo方法基本类似于File.关于二者,作何选择. ● 如果仅进行单一方法调用,则可以使用静态File类上 ...

  7. ubuntu 自动获取ip的怎么设置

    ubuntu以DHCP方式配置网卡自动获取ip编辑文件/etc/network/interfaces:sudo vi /etc/network/interfaces并用下面的行来替换有关eth0的行: ...

  8. php+redis实现电商秒杀功能

    这一次总结和分享用Redis实现分布式锁来完成电商的秒杀功能.先扯点个人观点,之前我看了一篇博文说博客园的文章大部分都是分享代码,博文里强调说分享思路比分享代码更重要(貌似大概是这个意思,若有误请谅解 ...

  9. Stammering Aliens

    Stammering Aliens Time Limit: 2000MS   Memory Limit: 65536K       Description Dr. Ellie Arroway has ...

  10. UVa11235 RMQ

    input 1<=n,q<=100000 升序序列a1 a2 a3 ... an -100000<=ai<=100000 q行i j 1<=i,j<=n 输入结束标 ...