一、time模块

%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 当前时区的名称
%% %号本身

格式化时间输出格式内容

时间的三种格式:

1.时间戳(timestamp)

是一串数字:1500875844,给计算机识别的

2.格式化时间:(formatstring)

是我们日常看到的日期:'2017-07-24 14:55:36'

3.结构化时间:(struct_time)

是处于时间戳与格式化时间的中间状态。

时间戳转为格式化时间

import  time
#时间戳转为格式化时间
time_stamp=time.localtime(1545093452.0)#先转为struct_time
print(time_stamp)
print(time.strftime('%Y-%m-%d %H:%M:%S',time_stamp))#前面是输出的格式,后面是中间状态struct_time。

格式化时间转为时间戳

import  time
struct_time=time.strptime('2018-12-18 08:37:32','%Y-%m-%d %H:%M:%S')#将格式化时间转为中间状态
print(time.mktime(struct_time))#再转为时间戳

二、random(随机数)

import random
#随机小数
print(random.random())#生成大于0小于1的随机小数
print(random.uniform(1,9.5))#生成大于1小于9的小数,参数可填小数。
#随机整数
print(random.randint(1,6))#生成大于1小于6的整数,参数不能是小数。
print(random.randrange(2,6,2))#随机生成2到6步长为2的整数,类似range函数。
#随机选择一个返回
print(random.choice([['sdfsa'],{'a':556},45]))#随机选择一个内容返回,任意数据格式。要放在列表或元组里。
#随机选择几个数返回,个数为函数的第二个参数。
print(random.sample(['sdfsa',{'a':556},45],2))#返回的是列表
#打乱列表顺序
lst=[15,3,9,68,0,12,5]
random.shuffle(lst)
print(lst)#直接打印原列表

#生成随机验证码

随机验证码
import random
def red_packet():
s=0
have = 0
name = {'小明': 0, '娜娜': 0, '木木': 0, '水水': 0}
name_lst = ['小明', '娜娜', '水水', '木木']
money = int(input('输入红包金额:'))
rang= int(input('输入红包个数:'))
if rang>len(name_lst):
print('红包数太大')
for i in range(0,rang-1):
leave=money-s
have=round(random.uniform(0.1,leave-0.1),1)
s=round(s,1)+round(have,1)
name1=random.choice(name_lst)
name_lst.remove(str(name1))
print( '恭喜{}获得{}元'.format(str(name1),str(have)))
name[name1]=name[name1]+have
last=round(money-round(s,1),1)
name2 = random.choice(name_lst)
name[name2] = name[name2]+last
print( '恭喜{}获得{}元'.format(str(name2),str(last)))
print(name)
red_packet()

发红包

三、os

os.makedirs('dirname1/dirname2')    可生成多层递归目录
os.removedirs('dirname1') 若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
os.mkdir('dirname') 生成单级目录;相当于shell中mkdir dirname
os.rmdir('dirname') 删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
os.listdir('dirname') 列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
os.remove() 删除一个文件
os.rename("oldname","newname") 重命名文件/目录
os.stat('path/filename') 获取文件/目录信息 os.system("bash command") 运行shell命令,直接显示
os.popen("bash command).read() 运行shell命令,获取执行结果
os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname") 改变当前脚本工作目录;相当于shell下cd os.path
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以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素
os.path.exists(path) 如果path存在,返回True;如果path不存在,返回False
os.path.isabs(path) 如果path是绝对路径,返回True
os.path.isfile(path) 如果path是一个存在的文件,返回True。否则返回False
os.path.isdir(path) 如果path是一个存在的目录,则返回True。否则返回False
os.path.join(path1[, path2[, ...]]) 将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
os.path.getatime(path) 返回path所指向的文件或者目录的最后访问时间
os.path.getmtime(path) 返回path所指向的文件或者目录的最后修改时间
os.path.getsize(path) 返回path的大小

四、序列化

将各种数据类型转化为字符串的过程叫序列化。

json

import json
#dumps,和loads
dic={'k1':'v1','k2':'v2','k3':'v3'}
d_dic=json.dumps(dic)
print(json.dumps(dic))#转为字符串的字典
print(json.loads(d_dic))#反序列化,将字符串格式的字符串类型转为字典
#上面两种可以处理嵌套的数据 #dump和load
with open('a1','wb')as f1:
json.dump(dic,f1)#直接将字典转为json字符串格式存入文件 with open('a1','r') as f1:
dic=json.load(f1)#将文件中的json字符串转为数据结构返回

pickle

import  pickle
dic = {'k1':'v1','k2':'v2','k3':'v3'}
p_dic=pickle.dumps(dic)
print(p_dic)#返回Bytes类型,二进制
print(pickle.loads(p_dic))#转为常规数据类型
with open('a1','wb') as f1:
pickle.dump(dic,f1)#写入二进制到文件 with open('a1','wb') as f1:
pickle.load(f1)#读取二进制

json与pickle的区别优势。

json是任何编程语言都能识别的,而pickle只能python识别,但是pickle可以将python中的任意数据类型序列化转为字符串类型。

python day27--常用模块 time,random,os,序列化的更多相关文章

  1. python 常用模块 time random os模块 sys模块 json & pickle shelve模块 xml模块 configparser hashlib subprocess logging re正则

    python 常用模块 time random os模块 sys模块 json & pickle shelve模块 xml模块 configparser hashlib  subprocess ...

  2. python 常用模块之random,os,sys 模块

    python 常用模块random,os,sys 模块 python全栈开发OS模块,Random模块,sys模块 OS模块 os模块是与操作系统交互的一个接口,常见的函数以及用法见一下代码: #OS ...

  3. python常用模块之random模块

    python常用模块之random模块 在程序中很多会用到随机字符,比如登陆网站的随机验证码,通过random模块可以很容易生成随机字符串 1.random.randrange():返回1-10之间的 ...

  4. python的常用模块之collections模块

    python的常用模块之collections模块 python全栈开发,模块,collections 认识模块 什么是模块?    常见的场景:一个模块就是一个包含了python定义和声明的文件,文 ...

  5. Python之常用模块(re,时间,random,os,sys,序列化模块)(Day20)

    一.时间模块 #常用方法 1.time.sleep(secs) (线程)推迟指定的时间运行.单位为秒. 2.time.time() 获取当前时间戳 在Python中表示时间的三种方式:时间戳,元组(s ...

  6. python 常用模块(一): random , time , sys , os模块部分知识.

    1.常用模块:(1)collectiaons模块 (2)与时间相关  time模块 (3)random模块 (4)os模块 (5)sys模块 (6) 序列化模块: json  ,   pickle 2 ...

  7. python之常用模块一(time、random、os、sys)

    摘要:时间模块time .随机模块random .os模块.sys模块 一.时间模块 三种格式 时间戳时间:浮点数 单位为秒 时间戳起始时间: 1970.1.1 0:0:0 英国伦敦时间 1970.1 ...

  8. random os 序列化 模块模块 随机选择

    # 1 random 模块 随机选择# import random#随机取小数# ret = random.random() #空是0到1之间的小数字# print(ret)# # 0.0799728 ...

  9. python常用模块json、os、sys

    一.序列化 json & pickle 模块 json--用于字符串和Python数据类型间进行转换 pickle---用于python特有的类型和Python的数据类型间进行转换 json: ...

随机推荐

  1. sublime Text 正则表达式功能使用介绍

    sublime Text 正则表达式功能使用介绍 1.打开sublime Text ,然后按 CTRL+H打开替换面板 2.如下图,勾选正则表达式功能,然后填上正则表达式和替换内容. 3.替换后结果如 ...

  2. jQuery 自执行函数

    jQuery 自执行函数 // 为了避免三方名冲突可将全局变量封装在自执行函数内 (function (arg) { var status = 1; arg.extend({ 'xsk': funct ...

  3. Maven+SSM框架(Spring+SpringMVC+MyBatis)(二)

    1.基本概念 2.开发环境搭建 3.Maven Web项目创建 4.SSM整合 此次整合我分两个配置文件: 1)分别是spring-mybatis.xml,包含spring和mybatis的配置文件, ...

  4. AJAX跨域问题以及解决思路(更新中)

    跨域的三大原因(同时满足) 浏览器限制 跨域 XHR请求 解决思路: 让浏览器不做限制,指定参数,让浏览器不做校验,但该方法不太合理,它需要每个人都去做改动. 不要发出XHR请求,这样就算是跨域,浏览 ...

  5. JDK的安装与测试

    一,下载并安装JDK1.8版本以上 1.Oracle官网下载地址:https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downl ...

  6. Ngnix配置

    server { listen 80; server_name www.local.test; root /data/workspace;  index index.php index.html in ...

  7. k-mean 拐点

    n = 100g = 6 set.seed(g)d <- data.frame(x = unlist(lapply(1:g, function(i) rnorm(n/g, runif(1)*i^ ...

  8. 7.8 GRASP原则八: 间接 Indirection

    GRASP原则八: 间接 Indirection  若两个对象直接连接,导致耦合太紧,如何解决?3.1 GRASP rule8: Indirection 间接  Name: Indirection ...

  9. [hdu P3085] Nightmare Ⅱ

    [hdu P3085] Nightmare Ⅱ Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...

  10. js实现下拉框模糊查询

    keyup方法触发模糊查询 list : Array<any> //下拉列表所有内容 filtList:Array<any> //过滤后的内容 inputContent : s ...