Python Day03
set
Collections系列:
Python拥有一些内置的数据类型,比如str, int, list, tuple, dict等, collections模块在这些内置数据类型的基础上,提供了几个额外的数据类型:
一、计数器:
Counter 是对字典的加工处理,功能是计算序列中元素出现的次数。
import collections import collections
obj = collections.Counter('testttteseess')
print (obj)
> Counter({'t': 5, 's': 4, 'e': 4}) # 统计各字符出现次数,并生成伪字典,key 是传入的元素,value 为元素出现的次数 obj = collections.Counter('testttteseess')
print (obj.most_common(5)) # 统计出现频率最高的5个字符,返回其值
> [('t', 5), ('e', 4), ('s', 4)]
elements enumerate
二、有序字典(orderedDict):
对字典功能的一个补充,在字典原有方法上,补充了一些方法,这些方法封装在 collections 中的 orderedDict 中。
默认使用 dict 时,key是无序的,在对dict 做迭代时,无法确定key 的顺序。
OrderedDict 的 key 会按照插入的顺序排列,而不是 key 本身排列。
内部原理:将字典的 key 放进有序的列表,再拿列表中的 key 去取字典中对应的 value。
# Python 内部即靠这种原理实现的字典有序
dic = {'name':'jay','sex':'boy','age':'','xxx':''}
for i in dic: # 每循环一次取出一个 key ,根据key 去字典中取对应值
print (dic[i])
import collections
dic = collections.OrderedDict()
dic['k1'] = 'v1'
dic['k3'] = 'v3'
dic['k2'] = 'v2'
print (dic()) # 无论取多少次,输出的顺序不会变。
> OrderedDict([('k1', 'v1'), ('k3', 'v3'), ('k2', 'v2')]) # for 循环取出所有 key 与对应 value
for k,v in dic.items():
print (k,v) > k1 v1
> k3 v3
> k2 v2
move_to_end():将指定的 key 移至字典最后位置
import collections
dic = collections.OrderedDict()
dic['k1'] = 'v1'
dic['k3'] = 'v3'
dic['k2'] = 'v2'
dic.move_to_end('k1') # 将 k1 与 k1 对应的值,移至字典最后
print (dic)
> OrderedDict([('k3', 'v3'), ('k2', 'v2'), ('k1', 'v1')]) # 此时 k1 已经在字典最后
popitem():后进先出,取出字典中最后一个 key 与其对应的 value
import collections
dic = collections.OrderedDict()
dic['k1'] = 'v1'
dic['k3'] = 'v3'
dic['k2'] = 'v2'
ret = dic.popitem() #移除并将返回值赋值给 ret 变量
print (dic)
print (ret)
> OrderedDict([('k1', 'v1'), ('k3', 'v3')]) # 原字典中内容
> ('k2', 'v2') # 移除并返回的内容
pop:移除指定 Key,并返回其 value
import collections
dic = collections.OrderedDict()
dic['k1'] = 'v1'
dic['k3'] = 'v3'
dic['k2'] = 'v2'
ret = dic.pop('k2') # 指定移除 k2
print (dic)
print (ret)
> OrderedDict([('k1', 'v1'), ('k3', 'v3')])
> v2 # 此处返回的是 k2 的值
setdefault(key,value):如果键不存在于字典中,则添加其 key 并将其值设定为默认值
import collections
dic = collections.OrderedDict()
dic['k1'] = 'v1'
dic.setdefault('k6','v8') # k6 不存在于字典中,会向字典中添加 k6
print (dic)
## 字典循环时,默认循环只输出出字典的 key。。。
三、默认字典(defaultdict):
import collections
dic = collections.defaultdict(list)
dic['k1'].append('jay')
print (dic)
四、可命名元组(namedtuple):
对元组的一个扩展,默认元组只能通过 [0]、[2] 这种索引去访问,可以将元组的值命名,访问元组的某个值时,可通过名字访问,x y 轴类似于这种。
# 导入模块
import collections
# 创建类,类名为 MytupleClass:
MytupleClass = collections.namedtuple('MytupleClass',['x','y','z']) obj = MytupleClass(11,22,33) # obj 就是根据 MytupleClass 类创建的对象
print (obj.x) # 通过可命名元组的 name 访问其内容。
print (obj.y) # 通过可命名元组的 name 访问其内容。
print (obj.z) # 通过可命名元组的 name 访问其内容。
> 11
> 22
> 33
五、队列 Queue:
深浅拷贝:
函数:
定义函数,函数在没有被调用时,不会被 Python 解释器所执行。
# 定义函数
def hello():
print "hello"
print "world"
print "hello" # 执行函数,当函数被执行时,才会被 Python 解释器所解释
hello()
return:
def show(): # 定义一个名为 show 的函数。
print ("a")
if 1 == 2: # 此判断永远不会被满足
return [11,22,33] # 当函数执行遇到 return 时,执行 return 代码并退出此函数(return 后的代码不会被执行)。
print ("b") ret = show() # 执行函数 show 并将返回值赋值给 ret,函数默认返回 None
print (ret) # 输出函数返回的内容。
> a # 函数 show 输出的内容 a
> b # 函数 show 输出的内容 b
> None # if 永远为假, return 没有被执行所以保存 show的返回值变量 ret 值为空,打印出 None
return:
def show(): # 定义一个名为 show 的函数。
print ("a")
if 1 == 1: # 此判断永远被满足
return [11,22,33] # 当函数执行遇到 return 时,执行 return代码并退出此函数(return 后的代码不会被执行)。
print ("b") ret = show() # 执行函数 show 并将返回值赋值给 ret ,函数默认返回 None
print (ret) # 输出函数返回的内容。
> a # 函数 show 输出的内容 a
> [11,22,33] # ret 变量保存的 函数 show return 出来的值。
形式参数与实际参数:
无参数:
show () # 函数执行时,() 为空代表无参数
一个参数:
def args_arg(arg): # (arg) 为形式参数
print (arg) # 打印传递进来的形式参数 args_arg("test vars") # 执行 args_arg 函数,并传递参数 () 中内容为实际参数
> test vars
两个参数:
def show(arg_1,arg_2):
print (arg_1,arg_2) show("hello",456) # 传递的实际参数个数,必须与函数中定义的形式参数个数相等
> hello 456
Python Day03的更多相关文章
- My way to Python - Day03
列表和字典的赋值 dict1 = {} dict1['k1'] = 'v1' list1 = [] list1.append('v1') 集合系列 1,计数器 Python 2.7.6 (defaul ...
- python———day03
一.字符串格式化输出: 占位符 %s(字符串) %d(整数) %f(浮点数,约等于小数) name = input("Name:") age = input("Ag ...
- python day03笔记总结
2019.3.29 S21 day03笔记总结 昨日回顾及补充 1.运算符补充 in not in 2.优先级 运算符与运算符之间也有优先级之分 今日内容 一.整型(int) py2 与 py3 的区 ...
- python day03作业
- 我的Python之旅第三天
一 编码操作 1 编码 enconde() 英文字符编码为"utf-8"时,一个字符占一个字节. s1='abcdef' b1=s1.encode('utf-8') print(b ...
- 【转】Python 内置函数 locals() 和globals()
Python 内置函数 locals() 和globals() 转自: https://blog.csdn.net/sxingming/article/details/52061630 1>这两 ...
- python操作haproxy.cfg文件
需求 1.查 输入:www.oldboy.org 获取当前backend下的所有记录 2.新建 输入: arg = { 'bakend': 'www.oldboy.org', 'record':{ ' ...
- Python基础-day03
写在前面 上课第三天,打卡: 不要让干净的灵魂染上尘埃,永远年轻.永远热泪盈眶 一.再谈编码 - 文件的概念 '文件' 是一个抽象的概念,是操作系统提供的外部存储设备的抽象,对应底层的硬盘:它是程序 ...
- python开发学习-day03(set集合、collection系列 、深浅拷贝、函数)
s12-20160116-day03 *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: ...
随机推荐
- ubuntu文件夹建立软链接方法
1:预备知识 -s 是代号(symbolic)的意思. 这里有两点要注意:第一,ln命令会保持每一处链接文件的同步性,也就是说,不论你改动了哪一处,其它的文件都会发生相同的变化:第二,ln的链接又软链 ...
- T-SQL编程 —— 用户自定义函数(标量函数)
用户自定义函数 在使用SQL server的时候,除了其内置的函数之外,还允许用户根据需要自己定义函数.根据用户定义函数返回值的类型,可以将用户定义的函数分为三个类别: 返回值为可更新表的函数 如果用 ...
- OpenLayers控制瓦片的绽放级别
先说说这个功能可能使用到的地方,当我们下载的网上瓦片或者矢量数据的第一级或开始几级效果不是很好时,我们就就想让用户看到这些级别的瓦片.实现这个功能比较简单,主要就是修改Openlayers.map的i ...
- Ubuntu 12.04 Virtualbox 启用USB 设备支持
转载自:http://www.cnblogs.com/ericsun/archive/2013/06/10/3130679.html 具体步骤在上面的链接中 今天在ubuntu下安装了Virtualb ...
- Manual——Test (翻译1)
LTE Manual ——Logging(翻译) (本文为个人学习笔记,如有不当的地方,欢迎指正!) 1.17.3 Testing framework(测试框架) ns-3 包含一个仿真核心引擎. ...
- iOS - Push 通知推送
1.UserNotifications 通知是 App 用来和用户交流的一种方式,特别是当 App 并没有在前台运行的时候.通知,正如它的名称所强调的,被用作向用户'通知'一个事件,或者仅仅向用户提示 ...
- python成长之路【第十篇】:浅析python select模块
一.select介绍 select()的机制中提供一fd_set的数据结构,实际上是一long类型的数组, 每一个数组元素都能与一打开的文件句柄(不管是Socket句柄,还是其他文件或命名管道或设备句 ...
- md语法之行内代码和代码片
md语法之行内代码和代码片 比如说要在行内写上一句或者半句代码(代码的意思就是某种脚本语言), 用撇号围起来就可以了. 比如: import pandas as pd 写代码片(单独的一块脚本语言)的 ...
- js获取当前日期时间格式为“yyyy-MM-dd HH:MM:SS”
废话不多说,直接上代码! <!DOCTYPE html><html><head> <meta charset="utf-8"> ...
- Docker部署Hadoop集群
Docker部署Hadoop集群 2016-09-27 杜亦舒 前几天写了文章"Hadoop 集群搭建"之后,一个朋友留言说希望介绍下如何使用Docker部署,这个建议很好,Doc ...