一.时间模块

  1. #常用方法
  2. 1.time.sleep(secs)
  3. (线程)推迟指定的时间运行。单位为秒。
  4. 2.time.time()
  5. 获取当前时间戳

在Python中表示时间的三种方式:时间戳,元组(struct_time), 格式化的时间字符串【时间戳为计算机能够识别的时间;时间字符串是人能够识别的时间;元组则是用来操作时间的】

  1. #导入时间模块
  2. >>>import time
  3.  
  4. #时间戳
  5. >>>time.time()
  6. 1500875844.800804
  7.  
  8. #时间字符串
  9. >>>time.strftime("%Y-%m-%d %X")
  10. '2017-07-24 13:54:37'
  11. >>>time.strftime("%Y-%m-%d %H-%M-%S")
  12. '2017-07-24 13-55-04'
  13.  
  14. #时间元组:localtime将一个时间戳转换为当前时区的struct_time
  15. time.localtime()
  16. time.struct_time(tm_year=2017, tm_mon=7, tm_mday=24,
  17.           tm_hour=13, tm_min=59, tm_sec=37,
  18. tm_wday=0, tm_yday=205, tm_isdst=0)

格式化时间字符串的表示

  1. %y 两位数的年份表示(00-99
  2. %Y 四位数的年份表示(000-9999
  3. %m 月份(01-12
  4. %d 月内中的一天(0-31
  5. %H 24小时制小时数(0-23
  6. %I 12小时制小时数(01-12
  7. %M 分钟数(00=59
  8. %S 秒(00-59
  9. %a 本地简化星期名称
  10. %A 本地完整星期名称
  11. %b 本地简化的月份名称
  12. %B 本地完整的月份名称
  13. %c 本地相应的日期表示和时间表示
  14. %j 年内的一天(001-366
  15. %p 本地A.M.或P.M.的等价符
  16. %U 一年中的星期数(00-53)星期天为星期的开始
  17. %w 星期(0-6),星期天为星期的开始
  18. %W 一年中的星期数(00-53)星期一为星期的开始
  19. %x 本地相应的日期表示
  20. %X 本地相应的时间表示
  21. %Z 当前时区的名称
  22. %% %号本身
  23.  
  24. python中时间日期格式化符号:

二.random模块

  1. >>> import random
  2. #随机小数
  3. >>> random.random() # 大于0且小于1之间的小数
  4. 0.7664338663654585
  5. >>> random.uniform(1,3) #大于1小于3的小数
  6. 1.6270147180533838
  7.  
  8. #随机整数
  9. >>> random.randint(1,5) # 大于等于1且小于等于5之间的整数
  10. >>> random.randrange(1,10,2) # 大于等于1且小于3之间的整数
  11.  
  12. #随机选择一个返回
  13. >>> random.choice([1,'',[4,5]]) # #1或者23或者[4,5]
  14. #随机选择多个返回,返回的个数为函数的第二个参数
  15. >>> random.sample([1,'',[4,5]],2) # #列表元素任意2个组合
  16. [[4, 5], '']
  17.  
  18. #打乱列表顺序
  19. >>> item=[1,3,5,7,9]
  20. >>> random.shuffle(item) # 打乱次序
  21. >>> item
  22. [5, 1, 3, 7, 9]
  23. >>> random.shuffle(item)
  24. >>> item
  25. [5, 9, 7, 1, 3]
  1. import random
  2.  
  3. def v_code():
  4.  
  5. code = ''
  6. for i in range(5):
  7.  
  8. num=random.randint(0,9)
  9. alf=chr(random.randint(65,90))
  10. add=random.choice([num,alf])
  11. code="".join([code,str(add)])
  12.  
  13. return code
  14.  
  15. print(v_code())
  16.  
  17. 生成验证码

生成随机验证码

三.os模块

os模块是操作系统交互的一个接口

  1. '''
  2. os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
  3. os.chdir("dirname") 改变当前脚本工作目录;相当于shell下cd
  4. os.curdir 返回当前目录: ('.')
  5. os.pardir 获取当前目录的父目录字符串名:('..')
  6. os.makedirs('dirname1/dirname2') 可生成多层递归目录
  7. os.removedirs('dirname1') 若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
  8. os.mkdir('dirname') 生成单级目录;相当于shell中mkdir dirname
  9. os.rmdir('dirname') 删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
  10. os.listdir('dirname') 列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
  11. os.remove() 删除一个文件
  12. os.rename("oldname","newname") 重命名文件/目录
  13. os.stat('path/filename') 获取文件/目录信息
  14. os.sep 输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/"
  15. os.linesep 输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n"
  16. os.pathsep 输出用于分割文件路径的字符串 win下为;,Linux下为:
  17. os.name 输出字符串指示当前使用平台。win->'nt'; Linux->'posix'
  18. os.system("bash command") 运行shell命令,直接显示
  19. os.popen("bash command) 运行shell命令,获取执行结果
  20. os.environ 获取系统环境变量
  21.  
  22. os.path
  23. os.path.abspath(path) 返回path规范化的绝对路径 os.path.split(path) 将path分割成目录和文件名二元组返回 os.path.dirname(path) 返回path的目录。其实就是os.path.split(path)的第一个元素 os.path.basename(path) 返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。
  24. 即os.path.split(path)的第二个元素
  25. os.path.exists(path) 如果path存在,返回True;如果path不存在,返回False
  26. os.path.isabs(path) 如果path是绝对路径,返回True
  27. os.path.isfile(path) 如果path是一个存在的文件,返回True。否则返回False
  28. os.path.isdir(path) 如果path是一个存在的目录,则返回True。否则返回False
  29. os.path.join(path1[, path2[, ...]]) 将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
  30. os.path.getatime(path) 返回path所指向的文件或者目录的最后访问时间
  31. os.path.getmtime(path) 返回path所指向的文件或者目录的最后修改时间
  32. os.path.getsize(path) 返回path的大小
  33. '''

注意:os.stat('path/filename')  获取文件/目录信息 的结构说明

  1. stat 结构:
  2.  
  3. st_mode: inode 保护模式
  4. st_ino: inode 节点号。
  5. st_dev: inode 驻留的设备。
  6. st_nlink: inode 的链接数。
  7. st_uid: 所有者的用户ID
  8. st_gid: 所有者的组ID
  9. st_size: 普通文件以字节为单位的大小;包含等待某些特殊文件的数据。
  10. st_atime: 上次访问的时间。
  11. st_mtime: 最后一次修改的时间。
  12. st_ctime: 由操作系统报告的"ctime"。在某些系统上(如Unix)是最新的元数据更改的时间,在其它系统上(如Windows)是创建时间(详细信息参见平台的文档)。
  13.  
  14. stat 结构

四.sys模块

sys模块是与Python解释器交互的一个接口

  1. sys.argv 命令行参数List,第一个元素是程序本身路径
  2. sys.exit(n) 退出程序,正常退出时exit(0)
  3. sys.version 获取Python解释程序的版本信息
  4. sys.maxint 最大的Int
  5. sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值
  6. sys.platform 返回操作系统平台名称

五.序列化模块

----------将原本的列表,字典等内容转换成一个字符串的过程叫做序列化

序列化的目的

1、以某种存储形式使自定义对象持久化
2、将对象从一个地方传递到另一个地方。
3、使程序更具维护性。

json模块

json模块提供了四个功能:dumps、dump、loads、load

  1. import json
  2. dic = {'k1':'v1','k2':'v2','k3':'v3'}
  3. str_dic = json.dumps(dic) #序列化:将一个字典转换成一个字符串
  4. print(type(str_dic),str_dic) #<class 'str'> {"k3": "v3", "k1": "v1", "k2": "v2"}
  5. #注意,json转换完的字符串类型的字典中的字符串是由""表示的
  6.  
  7. dic2 = json.loads(str_dic) #反序列化:将一个字符串格式的字典转换成一个字典
  8. #注意,要用json的loads功能处理的字符串类型的字典中的字符串必须由""表示
  9. print(type(dic2),dic2) #<class 'dict'> {'k1': 'v1', 'k2': 'v2', 'k3': 'v3'}
  10.  
  11. list_dic = [1,['a','b','c'],3,{'k1':'v1','k2':'v2'}]
  12. str_dic = json.dumps(list_dic) #也可以处理嵌套的数据类型
  13. print(type(str_dic),str_dic) #<class 'str'> [1, ["a", "b", "c"], 3, {"k1": "v1", "k2": "v2"}]
  14. list_dic2 = json.loads(str_dic)
  15. print(type(list_dic2),list_dic2) #<class 'list'> [1, ['a', 'b', 'c'], 3, {'k1': 'v1', 'k2': 'v2'}]
  16.  
  17. loadsdumps

dumps和loads

  1. import json
  2. f = open('json_file','w')
  3. dic = {'k1':'v1','k2':'v2','k3':'v3'}
  4. json.dump(dic,f) #dump方法接收一个文件句柄,直接将字典转换成json字符串写入文件
  5. f.close()
  6.  
  7. f = open('json_file')
  8. dic2 = json.load(f) #load方法接收一个文件句柄,直接将文件中的json字符串转换成数据结构返回
  9. f.close()
  10. print(type(dic2),dic2)
  11.  
  12. loaddump

load和dump

pickle

json & pickle模块

用于序列化的两个模快:

json:用于字符串和python数据类型之间的转换

pickle:用于python特有的类型 和 Python的数据类型之间的转换

    pickle模块提供了四个功能:dumps、dump(序列化,存)、loads(反序列化,读)、load  (不仅可以序列化字典,列表...可以把python中任意的数据类型序列化

  1. import pickle
  2. dic = {'k1':'v1','k2':'v2','k3':'v3'}
  3. str_dic = pickle.dumps(dic)
  4. print(str_dic) #一串二进制内容
  5.  
  6. dic2 = pickle.loads(str_dic)
  7. print(dic2) #字典
  8.  
  9. import time
  10. struct_time = time.localtime(1000000000)
  11. print(struct_time)
  12. f = open('pickle_file','wb')
  13. pickle.dump(struct_time,f)
  14. f.close()
  15.  
  16. f = open('pickle_file','rb')
  17. struct_time2 = pickle.load(f)
  18. print(struct_time.tm_year)
  19.  
  20. pickle

这时候机智的你又要说了,既然pickle如此强大,为什么还要学json呢?
这里我们要说明一下,json是一种所有的语言都可以识别的数据结构。
如果我们将一个字典或者序列化成了一个json存在文件里,那么java代码或者js代码也可以拿来用。
但是如果我们用pickle进行序列化,其他语言就不能读懂这是什么了~
所以,如果你序列化的内容是列表或者字典,我们非常推荐你使用json模块
但如果出于某种原因你不得不序列化其他的数据类型,而未来你还会用python对这个数据进行反序列化的话,那么就可以使用pickle

shelve

shelve也是python提供给我们的序列化工具,比pickle用起来更简单一些。
shelve只提供给我们一个open方法,是用key来访问的,使用起来和字典类似。

  1. import shelve
  2. f = shelve.open('shelve_file')
  3. f['key'] = {'int':10, 'float':9.5, 'string':'Sample data'} #直接对文件句柄操作,就可以存入数据
  4. f.close()
  5.  
  6. import shelve
  7. f1 = shelve.open('shelve_file')
  8. existing = f1['key'] #取出数据的时候也只需要直接用key获取即可,但是如果key不存在会报错
  9. f1.close()
  10. print(existing)
  11.  
  12. shelve

Python之常用模块(re,时间,random,os,sys,序列化模块)(Day20)的更多相关文章

  1. 2019-7-18 collections,time,random,os,sys,序列化模块(json和pickle)应用

    一.collections模块 1.具名元组:namedtuple(生成可以使用名字来访问元素的tuple) 表示坐标点x为1  y为2的坐标 注意:第二个参数可以传可迭代对象,也可以传字符串,但是字 ...

  2. collection,random,os,sys,序列化模块

    一.collection 模块 python拥有一些内置的数据类型,比如 str,list.tuple.dict.set等 collection模块在这些内置的数据类型的基础上,提供了额外的数据类型: ...

  3. day19:常用模块(collections,time,random,os,sys)

    1,正则复习,re.S,这个在用的最多,re.M多行模式,这个主要改变^和$的行为,每一行都是新串开头,每个回车都是结尾.re.L 在Windows和linux里面对一些特殊字符有不一样的识别,re. ...

  4. Python常用模块(logging&re&时间&random&os&sys&shutil&序列化&configparser&&hashlib)

    一. logging(日志模块) 二 .re模块 三. 时间模块 四. random模块 五. os模块 六. sys模块 七. shutil模块 八. 序列化模块(json&pickle&a ...

  5. 模块、包及常用模块(time/random/os/sys/shutil)

    一.模块 模块的本质就是一个.py 文件. 导入和调用模块: import module from module import xx from module.xx.xx import xx as re ...

  6. python time,random,os,sys,序列化模块

    一.time模块 表示时间的三种方式 在Python中,通常有这三种方式来表示时间:时间戳.元组(struct_time).格式化的时间字符串: (1)时间戳(timestamp) :通常来说,时间戳 ...

  7. 常用模块random,time,os,sys,序列化模块

    一丶random模块 取随机数的模块 #导入random模块 import random #取随机小数: r = random.random() #取大于零且小于一之间的小数 print(r) #0. ...

  8. python之模块random,time,os,sys,序列化模块(json,pickle),collection

    引入:什么是模块:   一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类型. 1.使用python编写的代码(.py ...

  9. 2018-11-13-常用模块1 (time random os sys)

    1.时间模块 time 2.随机数模块 random 3.与操作系统交互模块 os 4.系统模块 sys 在我们真正开始学习之前我们先解决下面几个问题,打好学习模块的小基础,以便更好的学习模块. (1 ...

  10. 模块:time,random,os,sys

    时间模块 import time # print(time.time()) #时间戳 # print(time.strftime('%Y-%m-%d %X')) #格式化字符 # print(time ...

随机推荐

  1. Appium python自动化测试系列之元素的定位(六)

    ​6.1 常用定位方法讲解 对象定位是自动化测试中很关键的一步,也可以说是最关键的一步,毕竟你对象都没定位那么你想操作也不行.所以本章节的知识我希望大家多动手去操作,不要仅仅只是书本上的知识,毕竟这个 ...

  2. Java基础08 继承(转载)

    继承(inheritance)是面向对象的重要概念.继承是除组合(composition)之外,提高代码重复可用性(reusibility)的另一种重要方式.组合是重复调用对象的功能接口.继承可以重复 ...

  3. 通过Get方式传递数据

    1:因为get传参数有个特点就是不能超过256字节.如果数据大的话会溢出. 解决办法: $data=json_encode($data_array); 然后在拼接超链接: <a href=&qu ...

  4. Tomcat运行流程

    Connector介绍 1.1 Connector的种类 Tomcat源码中与connector相关的类位于org.apache.coyote包中,Connector分为以下几类: Http Conn ...

  5. execute,executeQuery和executeUpdate的区别

    在jdbc中有3种执行sql的语句分别是execute,executeQuery和executeUpdate execute执行增删改查操作 execute返回的结果是个boolean型,当返回的是t ...

  6. jvm(12)-java内存模型与线程

    [0]README 0.1)本文部分文字描述转自“深入理解jvm”,旨在学习“java内存模型与线程” 的基础知识:   [1]概述 1)并发处理的广泛应用是使得 Amdahl 定律代替摩尔定律称为计 ...

  7. RMI 连接超时时间设定

    System.setProperty("sun.rmi.transport.tcp.responseTimeout", "2000"); System.setP ...

  8. hdu 3394(点双连通)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3394 思路:题目的意思是要求无向图中的冲突边和不需要边的条数,如果一个块中有多个环,则该块中的每条边都 ...

  9. java API Runtime 启动进程

    Runtime run = new Runtime.getRuntime(); Process p = run.exec("notepad.exe F:\\lesson\\a.java&qu ...

  10. 46、PopWindow工具类

    <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http: ...