1.如果执行文件不在项目根目录下,需要添加项目根目录到sys.path中
2.调用业务逻辑 2.logging模块
程序日志是 什么时间发生了什么事情,以及当时的情况
不是logging的话 记录日志的流程
1.定义一条日志信息
指定日志的标识符(即级别),方便后续查看日志
2.为期指定显示格式
3.输出到文件或者控制台 logging模块使用不同对象来完成上述几个步骤
logger完成第一步,生产第一个日志对象,并指定级别
多出来的filter用于 过滤日志
formatter完成第二步
handler完成第三步 如果获取的生成器已经存在则不会创建新的,直接将之前的给你 time 模块
用于处理时间相关的
1.获取时间
2.不同格式的时间转换
3.sleep函数 time.time() 浮点型的时间戳 从unix元年开始到现在的秒数
通常用于计算时间差,不用直接给用户看 print(time.asctime()) 格林威治时间格式
print(time.ctime()) 格林威治时间 格式 都是结构化时间(把时间拆为不同的部分)
print(time.gmtime()) 世界时间 比中国时间晚了八小时
time.localtime 获取本地时间 从结构化时间转为时间戳
time.mktime(time.localtime())) 将结构化时间转为格式化字符串时间
print(time.strftime('%Y-%m %h:%m:%s',time.localti么())
结构化可以单独获取某一个比如年份 月份
print(time.localtime().time_year) print(time.striptime('2019-01-23 10:46:44','%Y-%m %h:%m:%s')) import datetime
获取当前时间 会根据时区自动转换
print(datetime.datetime.now()) 创建datetime对象, 指定时间
print(datetime.datetime(2019,1,23)) 两个datetime可以进行减法运算,并且只能减
d1=datetime.datetime(2019,1,23))
d2=datetime.datetime(2019,1,24,10)
print(d2-d1) 可以单独获取某个部分
print(day2.hour) 时间差对象 表示30天
datetime.timedelta(days=30) 三十天以后是什么日子 时间差可以与datetime进行+和-
print(datetime.datetime.now()+dl) 两个时间差 可以进行+ - / random 随机数相关模块
计算机中的随机数都是伪随机
随机数是通过一个算法根据一个种子数计算得来的
只要知道了种子数,随机数的结果就是固定的
默认是使用当前的时间戳作为种子数
import random
print(random.random()) #从0-1 不包含1和0
print(random.randint(1,2)) 闭闭 包含开始和结束
print(random.randrange(1,3)) 闭开 包含开始不包含结束
print(random.choice[1,2,3,4,5]) 从列表中随机选一个
print(random.sample([1,2,3,4,5],2)) 从列表中随机选出指定的个数 打乱顺序(洗牌)
li=[1,2,3,4,5]
random.shuffle(li)
print(li) sys模块
与解释器相关的一些操作
system代表的不是操作系统而是解释器自己 import sys
获取/天机 环境变量
print(sys.path) 获取调用解释器时传递的参数 第一个永远是执行文件本身
print(sys.argv) 理解退出解释器
状态码可以自定义 执行为0
sys.exit(0) 查看已经加载的所有模块
print(sys.modules) print(sys.platform) 获取平台信息 print(sys.version) 获取解释器版本 pickle模块
是一个序列化模块
序列化指的是把一种数据类型转换成另一种数据类型 目的是为了传输或存储数据
目的是为了 永久存储或是进行网络传输
pickle 模块序列化得到的数据只能被pickle来反序列化
如果你写的是一个单机程序 可以使用该模块
对于网络应用程序而言我们需要一种任何语言平台都能识别的数据类型
这就是json和xml 序列化的过程 就是从python数据类型转换为中间类型
反序列化 指的是从中间数据类型 恢复到python的数据类型 dumps 将python数据类型转为字节
dump 封装了write函数的调用(序列化)
loads 是将字节转为python数据类型
load 封装了read函数的调用(反序列化)
pickle序列化得到的数据 不能跨平台

模块之 logging模块 time 模块 random模块 sys模块 pickle模块的更多相关文章

  1. Python-hashlib、OS、Random、sys、zipfile模块

    # print(sys.version) #python 版本 # print(sys.path) # print(sys.platform) #当前什么系统 # print(sys.argv) #当 ...

  2. 包及常用模块(time、datetime、random、sys)

    什么是包?‘ #官网解释 Packages are a way of structuring Python’s module namespace by using “dotted module nam ...

  3. random,time,sys,os,序列化模块

    random模块(随机数模块) 取随机小数: random.random() 取0-1之间的小数 random.uniform(x, y) 取x-y之间的小数 取随机整数: random.randin ...

  4. python笔记6 模块与包 程序开发规范 包 re sys time os模块

    模块与包 python 模块首引用加载到内存,如果再次引用此模块,直接从内存中读取. python文件分为:执行文件(解释器运行的文件),被引用文件(import) 模块引用一共发生了3件事: 1.他 ...

  5. Day 17 time,datetime,random,os,sys,json,pickle

    time模块 1.作用:打印时间,需要时间的地方,暂停程序的功能 时间戳形式 time.time() # 1560129555.4663873(python中从1970年开始计算过去了多少秒) 格式化 ...

  6. python之常见模块(time,datetime,random,os,sys,json,pickle)

    目录 time 为什么要有time模块,time模块有什么用?(自己总结) 1. 记录某一项操作的时间 2. 让某一块代码逻辑延迟执行 时间的形式 时间戳形式 格式化时间 结构化时间 时间转化 总结: ...

  7. python模块(json和pickle模块)

    json和pickle模块,两个都是用于序列化的模块 • json模块,用于字符串与python数据类型之间的转换 • pickle模块,用于python特有类型与python数据类型之间的转换 两个 ...

  8. python数据持久存储-pickle模块

    pickle模块实现了基本的数据序列和反序列化.pickle模块的序列化操作我们能够将程序中运行的对象信息保存到文件中去,通过pickle模块的反序列化操作,能够从文件中创建上一次程序保存的对象. 接 ...

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

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

随机推荐

  1. 借鉴redux,实现一个react状态管理方案

    react状态管理方案有很多,其中最简单的最常用的是redux. redux实现 redux做状态管理,是利用reducer和action实现的state的更新. 如果想要用redux,需要几个步骤 ...

  2. Java日志格式应该是占位符还是字符串拼接

    背景 ​ 上次在群中,有个群友说自己把所有项目中,所有使用占位符打印日志的方式都修改成为了字符串拼接的方式,因为他曾经看了一篇文章,说字符串拼接的形式比占位符形式的性能更好,这个话题引起了大家的广泛讨 ...

  3. HDU 5496——Beauty of Sequence——————【考虑局部】

    Beauty of Sequence Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Other ...

  4. JS中关于clientWidth offsetWidth scrollWidth 等的区别

    网页可见区域宽: document.body.clientWidth;网页可见区域高: document.body.clientHeight;网页可见区域宽: document.body.offset ...

  5. Linux文件的三个时间属性(Atime,Mtime,Ctime)

    Linux下,一个文件有三种时间,分别是: 访问时间:atime 修改时间:mtime 状态时间:ctime 访问时间:对文件进行一次读操作,它的访问时间就会改变.例如像:cat.more等操作,但是 ...

  6. zabbix-2.2.2(Ubuntu 14.04 LTS/OpenLogic 7.2)

    平台: arm 类型: ARM 模板 软件包: apache-2.4.7 mariadb-5.5.50 mysql-5.5.52-0ubuntu0.14.04.1 php-5.4.16 php-5.5 ...

  7. 华为服务器操作系统EulerOS V2.0

    平台: linux 类型: 虚拟机镜像 软件包: java-1.8.0 php-5.4.16 python-2.7.5 qt-4.8.5 tomcat-7.0.69 basic software eu ...

  8. Linux最常用命令实战

    1.改变机器的名称: vim /etc/hostname Master 在文件中修改机器名称为我们想要的名称(相当于域名) 可以通过shutdown -h now 关闭 2.查看当前机器IP: ifc ...

  9. .Net创建Windows服务完成批量导出功能(错误速查)

    无法打开计算机“.”上的服务控制管理器.此操作可能需要其他特权. 无法将类型为“Microsoft.Office.Interop.Word.ApplicationClass”的 COM 对象强制转换为 ...

  10. Android SDK下载OpenMobile api

    在Android SDK Manager的Tools -> Manager Add-on sites... -> User Defined Sites中,添加以下地址: http://se ...