- 第一篇Python数据类型详解01中主要介绍了
Python
中的一些常用的数据类型的基础知识 - 第二篇Python数据类型详解02文章中, 详细介绍了数字(
Number
)和字符串的一些函数和模块的使用 - 这篇文章主要介绍一些
Python
中的一序列(列表/元组/字典)
列表(List)
先回顾下上一篇Python数据类型详解01文章中介绍的列表的基础知识
1 | # List 列表 |
添加和删除列表元素
对列表的数据项进行修改或更新,你也可以使用append()方法来添加列表项
1 | list1 = [] ## 空列表 |
使用 del
语句来删除列表的元素
1 | del list1[1] |
列表脚本操作符
列表对 + 和 星号 的操作符与字符串相似。+ 号用于组合列表,星号 号用于重复列表
1 | # 1. 脚本操作符 |
列表函数&方法
下面将会列出在列表中常用的函数和方法
函数表达式 | 输出结果 | 描述 |
---|---|---|
len(list1) |
3 | 列表元素个数 |
max([1, 2, 's']) |
s | 返回列表元素的最大值 |
min([1, 2, 's']) |
1 | 返回列表元素的最小值 |
list(('q', 1) |
['q', 1] |
将元组转换为列表 |
list1.append(2) |
[1, 2, 3, 2] | 在列表末尾添加新的对象 |
list1.count(2) |
2 | 统计某个元素在列表中出现的次数 |
list1.index(3) |
2 | 从列表中找出某个值第一个匹配项的索引位置 |
list1.insert(1, 'jun') |
[1, ‘jun’, 2, 3, 2] | 将对象插入列表的指定位置 |
list1.remove(3) |
[1, ‘jun’, 2, 2] | 移除列表中某个值的第一个匹配项 |
list1.reverse() |
[2, 2, ‘jun’, 1] | 对列表的元素进行反向排列 |
list1.sort() |
[2, 2, ‘jun’, 1] | 对原列表进行排序, 如果指定参数,则使用比较函数指定的比较函数 |
extend()方法
用于在列表末尾一次性追加另一个序列(元组和列表)中的多个值(用新列表扩展原来的列表)
1 | list3 = [12, 'as', 45] |
pop()方法
用于移除列表中的一个元素(默认最后一个元素),并且返回该元素的值
1 | list.pop(obj=list[-1]) |
元组
先回顾一下上篇文章介绍的元组的基础知识
1 | # 元组 |
元组运算符
与列表的运算符和操作类似, 如下:
1 | # 计算元素个数 |
元组内置函数
1 | tuple1 = (1, 2, 4, 5) |
字典
先看看上文中介绍到的字典的相关基础知识, 需要注意的是: 键必须不可变,所以可以用数字,字符串或元组充当,所以用列表就不行
1 | # 字典 |
内置函数
1 | dic1 = {'name': 'titan', 'age':20} |
内置方法
copy()方法
copy()
函数返回一个字典的浅复制- 直接赋值和
copy
的区别
1 | dict1 = {'user':'runoob','num':[1,2,3]} |
实例中 dict2
其实是 dict1
的引用(别名),所以输出结果都是一致的,dict3
父对象进行了深拷贝,不会随dict1
修改而修改,子对象是浅拷贝所以随 dict1
的修改而修改
fromkeys()方法
fromkeys()
函数用于创建一个新字典,- 参数一: 以序列
seq
中元素做字典的键 - 参数二:
value
为字典所有键对应的初始值(可选参数)
1 | dict.fromkeys(seq[, value]) |
get() 和 setdefault()方法
get()
函数返回指定键的值,如果值不在字典中返回默认值setdefault()
和get()
方法类似, 如果键不存在于字典中,将会添加键并将值设为默认值(同事也会把键值对添加到字典中)- 参数一: 字典中要查找的键。
- 参数二: 如果指定键的值不存在时,返回该默认值值(可选参数)
1 | dict.get(key, default=None) |
update()方法
把字典的键/值对更新到另一个字典里(合并字典)
1 | dict.update(dict2) |
pop() 和 popitem() 方法
pop()
: 删除字典给定键 key 所对应的值,返回值为被删除的值。key值必须给出。 否则,返回default值popitem()
: 随机返回并删除字典中的一对键和值。
如果字典已经为空,却调用了此方法,就报出KeyError异常
1 | pop(key[,default]) |
其他方法
1 | dic2 = {'name': 'titan', 'age':20} |
日期和时间
Python
提供了一个time
和calendar
- 模块可以用于格式化日期和时间。
- 时间间隔是以秒为单位的浮点小数。
- 每个时间戳都以自从1970年1月1日午夜(历元)经过了多长时间来表示
- 在介绍时间之前, 先介绍一下什么时间元组
属性 | 描述 | 取值 |
---|---|---|
tm_year | 4位数年 | 2018 |
tm_mon | 月 | 1 到 12 |
tm_mday | 日 | 1到31 |
tm_hour | 小时 | 0 到 23 |
tm_min | 分钟 | 0 到 59 |
tm_sec | 秒 | 0 到 61 (60或61 是闰秒) |
tm_wday | 礼拜几 | 0到6 (0是周一) |
tm_yday | 一年的第几日 | 1 到 366(儒略历) |
tm_isdst | 夏令时 | -1, 0, 1, -1是决定是否为夏令时的旗帜 |
获取时间的简单示例
1 | # 日期和时间 |
格式化日期
先看几个简单示例
1 | # 1.格式化日期 |
- 这里介绍下上面用到的相关
Python
中时间和日期相关的格式化符号%y
: 两位数的年份表示(00-99)%Y
: 四位数的年份表示(000-9999)%m
: 月份(01-12)%d
: 月内中的一天(0-31)%H
: 24小时制小时数(0-23)%I
: 12小时制小时数(01-12)%M
: 分钟数(00=59)%S
: 秒(00-59)%a
: 本地简化星期名称%A
: 本地完整星期名称%b
: 本地简化的月份名称%B
: 本地完整的月份名称%c
: 本地相应的日期表示和时间表示%j
: 年内的一天(001-366)%p
: 本地A.M.或P.M.的等价符%U
: 一年中的星期数(00-53)星期天为星期的开始%w
: 星期(0-6),星期天为星期的开始%W
: 一年中的星期数(00-53)星期一为星期的开始%x
: 本地相应的日期表示%X
: 本地相应的时间表示%Z
: 当前时区的名称%%
: %号本身
Time 模块
Time
模块包含了以下内置函数,既有时间处理相的,也有转换时间格式的
Time模块的属性
timezone
: 当地时区(未启动夏令时)距离格林威治的偏移秒数(>0,美洲;<=0大部分欧洲,亚洲,非洲)tzname
: 包含一对根据情况的不同而不同的字符串,分别是带夏令时的本地时区名称,和不带的
1 | print(time.timezone) |
altzone()方法
返回格林威治西部的夏令时地区的偏移秒数。如果该地区在格林威治东部会返回负值(如西欧,包括英国)。对夏令时启用地区才能使用
1 | print(time.altzone) |
asctime()方法
接受时间元组并返回一个可读的形式为"Tue Dec 11 18:07:14 2008"
(2008年12月11日 周二18时07分14秒)的24个字符的字符串
1 | localTime = time.localtime() |
ctime() 和 gmtime() 和 localtime()方法
ctime
: 把一个时间戳(按秒计算的浮点数)转化为time.asctime()
的形式。gmtime
: 将一个时间戳转换为UTC时区(0时区)的struct_time
(struct_time是在time
模块中定义的表示时间的对象)localtime
: 类似gmtime
,作用是格式化时间戳为本地的时间- 如果参数未给或者为None的时候,将会默认
time.time()
为参数
1 | time.ctime([ sec ]) |
gmtime()方法
- 接收
struct_time
对象作为参数,返回用秒数来表示时间的浮点数 - 如果输入的值不是一个合法的时间,将触发
OverflowError
或ValueError
- 参数: 结构化的时间或者完整的9位元组元素
1 | time.mktime(t) |
sleep()方法
推迟调用线程,可通过参数secs
指秒数,表示进程推迟的时间
1 | time.sleep(t) |
strftime()方法
- 接收以时间元组,并返回以可读字符串表示的当地时间,格式由参数
format
决定, 上面已经简单介绍过了 - 参数
format
– 格式字符串 - 参数
t
– 可选的参数t是一个struct_time
对象
1 | time.strftime(format[, t]) |
strptime()方法
- 函数根据指定的格式把一个时间字符串解析为时间元组
- 参数一: 时间字符串
- 参数二: 格式化字符串
1 | time.strptime(string[, format]) |
tzset()方法
根据环境变量TZ重新初始化时间相关设置, 标准TZ环境变量格式:
1 | std offset [dst [offset [,start[/time], end[/time]]]] |
std
和dst
: 三个或者多个时间的缩写字母。传递给time.tzname
.offset
: 距UTC
的偏移,格式:[+|-]hh[:mm[:ss]] {h=0-23, m/s=0-59}
。start[/time]
,end[/time]
:DST
开始生效时的日期。格式为m.w.d
— 代表日期的月份、周数和日期。w=1
指月份中的第一周,而w=5
指月份的最后一周。start
和end
可以是以下格式之一:Jn
: 儒略日n (1 <= n <= 365)
。闰年日(2月29)不计算在内。n
: 儒略日(0 <= n <= 365)
。 闰年日(2月29)计算在内Mm.n.d
: 日期的月份、周数和日期。w=1
指月份中的第一周,而w=5
指月份的最后一周。time
:(可选)DST
开始生效时的时间(24 小时制)。默认值为 02:00(指定时区的本地时间)
1 | # 没有返回值 |
日历(Calendar)模块
- 此模块的函数都是日历相关的,例如打印某月的字符月历。
- 星期一是默认的每周第一天,星期天是默认的最后一天。
- 介绍一下
Calendar
模块的相关函数
1 | # 返回当前每周起始日期的设置, 默认情况下,首次载入caendar模块时返回0,即星期一 |
calendar
和 prcal
方法
返回一个多行字符串格式的year年年历,3个月一行,间隔距离为c
。 每日宽度间隔为w
字符。每行长度为21* W+18+2* C
。l
是每星期行数
1 | calendar.calendar(year,w=2,l=1,c=6) |
month
和 prmonth
方法
返回一个多行字符串格式的year
年month
月日历,两行标题,一周一行。每日宽度间隔为w
字符。每行的长度为7* w+6
。l
是每星期的行数
1 | calendar.month(year,month,w=2,l=1) |
timegm
方法
和time.gmtime
相反:接受一个时间元组形式,返回该时刻的时间戳(1970纪元后经过的浮点秒数)
1 | calendar.timegm(tupletime) |
- 到这里,
Python
相关的数据类型(数字, 字符串, 元组, 列表和字典)基本都介绍完毕了 Python
中的常用的时间格式和时间相关的模块(time
和calendar
)也都介绍完了- 文章中有些地方可能也不是很全面, 会继续努力
- 另外, 在
Python
中,其他处理日期和时间的模块还有:datetime模块 和 dateutil模块 - 这两个模块这里也不再详细介绍了,
Python
相关文章后期会持续更新……