目录

time 模块

为什么要有time模块,time模块有什么用?

time模块用来打印时间,并且有暂停程序的功能,需要时间的地方就要调用。

time模块的三种格式

时间戳(timestamp)

时间戳表示的是从1970年1月1日0:00:00开始按秒计算的偏移量

import time
print(time.time()) 1560166598.8710632

格式化时间(需要自己定义格式)

格式化时间就是普通字符串格式的时间表示方式,需要自己定义格式。

print(time.strftime('%Y-%m-%d'))
2019-06-10

结构化时间(struct—time)

print(time.localtime()) # 北京时间
time.struct_time(tm_year=2019, tm_mon=6, tm_mday=10, tm_hour=19, tm_min=42, tm_sec=45, tm_wday=0, tm_yday=161, tm_isdst=0) print(time.gmtime()) # 格林威治时间(时间标准时间)
time.struct_time(tm_year=2019, tm_mon=6, tm_mday=10, tm_hour=11, tm_min=43, tm_sec=46, tm_wday=0, tm_yday=161, tm_isdst=0)

结构化时间转换为格式化时间

struct_time = time.localtime()
print(time.strftime('%Y-%m-%d',struct_time)) 2019-06-10

结构化时间转换为时间戳

print(time.mktime(struct_time))
1560167473.0

时间戳转换成结构化时间

stamp_time = time.time()
print(time.localtime(stamp_time)) time.struct_time(tm_year=2019, tm_mon=6, tm_mday=10, tm_hour=19, tm_min=55, tm_sec=25, tm_wday=0, tm_yday=161, tm_isdst=0)

格式化时间转换成结构化时间

print(time.strptime('2019-06-01 12:00:00','%Y-%m-%d %X'))

time.struct_time(tm_year=2019, tm_mon=6, tm_mday=1, tm_hour=12, tm_min=0, tm_sec=0, tm_wday=5, tm_yday=152, tm_isdst=-1)

程序延时

time.sleep(1)

datetime 模块

为什么要有datetime模块,有什么用?

datetime模块能进行时间的加减

获取当前时间

import datetime

now = datetime.datetime.now()
print(now) 2019-06-10 20:05:05.697198

时间的加减

print(now + datetime.timedelta(3))  # 3代表的参数表示天数,且里面的参数只能是天,不能进行年和月的加减

print(now + datetime.timedelta(-3))

2019-06-13 20:06:34.748685
2019-06-07 20:09:11.633673

时间的年月日的修改

print(now.replace(year=2010,month=6,day=8,hour=19,minute=10,second=11))

2010-06-08 19:10:11.641058

random 模块

为什么要有random模块,有什么用?

  • 打印(0,1)之间的数, 不会取0和1
print(random.random())
0.9112520136212495
  • 打印[n,m]的整数 # 会去n和m

    print(random.randint(1,5))
    
    1
  • 打印(n,m)的小数

    print(random.uniform(1,5))
    
    4.66308974253497
  • 打印[n,m)的整数 取头不取尾

    print(random.randrange(1,3))
    
    1

    从容器中随机选择一个(牢记,经常用) 抽奖程序就是基于这个基础做出来的

    res = random.choices([1,4,7,9])
    print(res) [4]

    抽奖实例:

    count =0
    while True:
    res = random.choices([1000,22,333,44])
    count +=500
    if count == 3000:
    print(f'恭喜你获得1000元大奖')
    else:
    if res ==1000:
    print('再来一次!')
    else:
    print(f'恭喜你获得{res}')

从容器中随机选择多个(牢记,经常用)

```python
print(random.sample([1,2,'w','t'],2))
[1, 'w']
```

打乱容器顺序(牢记)

lis = [1,2,3,4]
random.shuffle(lis)
print(lis) [3, 1, 2, 4]

os模块(与操作系统交互)

os模块与操作系统交互,在python中进行文件操作

  • 创建文件夹 os.mkdir()
  • 删除文件夹,递归往上删除空文件夹 os.removedirs()
  • 删除一个空文件夹 os.rmdir()
  • 列出文件夹所有文件名和隐藏文件名 os.listdir()
  • 删除文件 os.remove()
  • 重命名文件名 os.rename()
  • 打印环境变量 os.envirom()
  • 添加环境变量 os.path.dirname(‘程序执行文件所在的文件夹路径’)重点
  • 判断文件是否存在 os.path.exists()
  • 拼接文件路径(因为不同系统的路径拼接符不一样)os.path.join()
  • 计算文件大小 os.path.getsize()重点
  • 打印文件夹下所有文件夹和文件 os.walk()

sys 模块(与python交互)

  • 查看当前文件路径 sys.argv() 重点

    print(sys.argv)
    
    ['D:/pycharm学习笔记/test1/test-6-10.py']
  • 获取解释器版本 sys.hexversion

    print(sys.hexversion)
    50726128
  • 获取当前文件导入模块的路径 sys.path 重点

    print(sys.path)
    
    ['D:\\pycharm学习笔记\\test1', 'D:\\pycharm学习笔记', 'D:\\python3\\python36.zip', 'D:\\python3\\DLLs', 'D:\\python3\\lib', 'D:\\python3', 'D:\\python3\\lib\\site-packages', 'D:\\pycharm\\PyCharm 2018.1.4\\helpers\\pycharm_matplotlib_backend']

json 模块 与pickle 模块

序列化(dump)

从内存到硬盘这个过程叫做序列化,序列化必须得规定格式

特点:

  • 持久保存状态
  • 跨平台交互数据(但只能存dict/list/str/int/float/bool/None)
with open('文件.json','w',encoding='utf8') as fw:
json.dump(dict,fw)

反序列化 (load)

with open('文件.json','r',encoding='utf8') as fr:
data = json.load(fr)

pickle

  • pickle也是序列化和反序列化,json可以跨平台,只支持dict/list/str/int/float/bool/None

  • pickle支持python中任意数据类型,所以不能跨平台(不同平台的函数一定是不同的),pickle模块序列化过程是以二进制形式转换

序列化

with open('文件.json','wb') as fw:
pickle.dump(dict,fw)

反序列化

with open('文件.json','rb') as fr:
data = pickle.load(fr)

python-time模块--pickle模块的更多相关文章

  1. python(31)——【sys模块】【json模块 & pickle模块】

    一.sys模块 import sys sys.argv #命令行参数List,第一个元素是程序本身路径 sys.exit() #退出程序,正常退出时exit(0) sys.version #获取pyt ...

  2. Python进阶(九)----json模块, pickle模块, os模块,sys模块,hashlib模块

    Python进阶----json模块, pickle模块, os模块,sys模块,hashlib模块 一丶序列化模块 什么是序列化: ​ 将一种数据结构,转换成一个特殊的序列(特殊字符串,用于网络传输 ...

  3. sys模块&json模块&pickle模块

    sys模块&json模块&pickle模块 sys模块 一.导入方式 import sys 二.作用 与Python解释器交互 三.模块功能 3.1 经常使用 sys.path #返回 ...

  4. [python标准库]Pickle模块

    Pickle-------python对象序列化 本文主要阐述以下几点: 1.pickle模块简介 2.pickle模块提供的方法 3.注意事项 4.实例解析 1.pickle模块简介 The pic ...

  5. python 常用模块(一): os模块,序列化模块(json模块 pickle模块 )

    1.os模块 2.序列化模块:(1)json模块 和 pickle模块 一.os模块 os.path.abspath: (1)把路径中不符合规范的/改成操作系统默认的格式 import os path ...

  6. Python json和pickle模块

    用于序列化的两个模块 json,用于字符串 和 python数据类型间进行转换 pickle,用于python特有的类型 和 python的数据类型间进行转换 Json模块提供了四个功能:dumps. ...

  7. day19 python模块 json模块 pickle模块

    day19 python   一.序列化模块     序列类型: 列表 字符串 元组 bytes     序列化: 特指字符串和bytes, 就是把其他的数据类型转化成序列的数据类型的过程 dic = ...

  8. python学习-50 pickle模块

    pickle模块 与json方法是一样的 import pickle dic = {'} print(type(dic)) a = pickle.dumps(dic) print(type(a)) f ...

  9. Python学习笔记——pickle 模块

    由于从文本文件中读取出来的内容都会变成字符串,且转换成列表.字典等数据类型比较困难,因此采用pickle模块存储它们 import pickle my_list = [123,3.14,'小甲鱼',[ ...

  10. 模块之 logging模块 time 模块 random模块 sys模块 pickle模块

    1.如果执行文件不在项目根目录下,需要添加项目根目录到sys.path中2.调用业务逻辑 2.logging模块 程序日志是 什么时间发生了什么事情,以及当时的情况 不是logging的话 记录日志的 ...

随机推荐

  1. python 6 循环

    循环 要计算1+2+3,我们可以直接写表达式: >>> 1 + 2 + 3 6 要计算1+2+3+...+10,勉强也能写出来. 但是,要计算1+2+3+...+10000,直接写表 ...

  2. 看懂物联网fr

        看懂物联网 2015-10-11 物联网世界 1.第三次IT浪潮 互联网时代的特征是信息驱动了生产力,无论众包.订单式生产这些理论:还是B2C.O2O各类业务模式:归根结底,是信息优化了生产关 ...

  3. Angular2中实现基于TypeScript的对象合并方法:extend()

    TypeScript里面没有现成的合并对象的方法,这里借鉴jQuery里的$.extend()方法.写了一个TypeScript的对象合并方法,使用方法和jQuery一样. 部分代码和jQuery代码 ...

  4. 百度地图API的基本用法

    首先 ,如果想调用百度地图api,你需要获取一个百度地图api的密钥. 申请秘钥的步骤: 1.搜索百度地图: 2.进入后,先登录然后点击申请密钥: 3. 4.申请成功,拥有密钥 有了密钥之后,引入百度 ...

  5. git如何强制用远程分支更新本地

    git本地即使有修改如何强制更新: 本地有修改和提交,如何强制用远程的库更新本地.我尝试过用git pull -f,总是提示 You have not concluded your merge. (M ...

  6. centos7使用yum安装不了ffmpeg

    [root@localhost]# yum install ffmpeg Loaded plugins: fastestmirror Loading mirror speeds from cached ...

  7. SqlServer中嵌套事务使用--事务计数指示 BEGIN 和 COMMIT 语句的数目不匹配 --根本问题

    转自  :SqlServer中嵌套事务使用--事务计数指示 BEGIN 和 COMMIT 语句的数目不匹配 --根本问题 问题: 1. System.Data.SqlClient.SqlExcepti ...

  8. 挂sqlserver计划,系统自动分配拣货任务

    USE [P2WMS_WH43] GO /****** Object: StoredProcedure [dbo].[sp_fru_CalcAllocatePickData] Script Date: ...

  9. Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'fundService': Injection of resource dependencies failed;

    在进行SSM的Controller的编写, 从浏览器访问后端Controller的时候遇到了这个问题. 这个问题的描述: 创建Bean的对象失败 错误代码如下: @Service("fund ...

  10. String中关于BeanFactory

    org.springframework.beans及org.springframework.context包是Spring IoC容器的基础.BeanFactory提供的高级配置机制,使得管理任何性质 ...