Python基础编程常用模块汇总

Stella981
• 阅读 667

3.8 json模块重点

json模块是将满足条件的数据结构转化成特殊的字符串,并且也可以反序列化还原回去。

  • 不同语言都遵循的一种数据转化格式,即不同语言都使用的特殊字符串。(比如Python的一个列表[1, 2, 3]利用json转化成特殊的字符串,然后在编码成bytes发送给php的开发者,php的开发者就可以解码成特殊的字符串,然后在反解成原数组(列表): [1, 2, 3])
  • json序列化只支持部分Python数据结构:dict,list, tuple,str,int, float,True,False,None

用于网络传输,和文件写读:dumps(转化成str)loads(转回去)

网络传输

import json                        #导入json模块
dic={1:'李文浩',2:'聂冰',3:'赵秋雨'}
new_dic=json.dumps(dic,ensure_ascii=False)            #将dict格式转化成str格式
print(new_dic,type(new_dic)#{"1": "李文浩", "2": "聂冰", "3": "赵秋雨"} <class 'str'>
old_b=old_dic.encode('utf-8')        #将str模式的字典转化成byts类型编码
    #模拟网络传输
    new_b=old_b.decode('utf-8')        #解码
new_dic=json.loads(new_b)            #转化成字典类型
print(new_dic,type(new_dic))

文件写入

  • 单行写入

    import json dic={1:'李文浩',2:'聂冰',3:'赵秋雨'} with open('json测试.json',mode='w',encoding='utf-8')as f1: old_dic=json.dumps(dic,ensure_ascii=False) f1.write(old_dic) with open('json测试.json',encoding='utf-8')as f2: print(json.loads(f2.read()))

  • 多行写入

    dic1 = {'name':'oldboy1'} dic2 = {'name':'oldboy2'} dic3 = {'name':'oldboy3'} f = open('序列化',encoding='utf-8',mode='a') str1 = json.dumps(dic1) f.write(str1+'\n') str2 = json.dumps(dic2) f.write(str2+'\n') str3 = json.dumps(dic3) f.write(str3+'\n') f.close() ​ f = open('序列化',encoding='utf-8') for line in f: print(json.loads(line))

用于单个数据文件写读:dump、load

import json
f = open('json_file.json','w')
dic = {'k1':'v1','k2':'v2','k3':'v3'}
json.dump(dic,f)  #dump方法接收一个文件句柄,直接将字典转换成json字符串写入文件
f.close()
# json文件也是文件,就是专门存储json字符串的文件。
f = open('json_file.json')
dic2 = json.load(f)  #load方法接收一个文件句柄,直接将文件中的json字符串转换成数据结构返回
f.close()
print(type(dic2),dic2)

3.9pickle模块

用于网络传输:dumps、loads

import pickle
dic={1:'李文浩',2:'聂冰',3:'赵秋雨'}
str_dic=pickle.dumps(dic)
print(str_dic)            #bytes类型
dic2=pickle.loads(str_dic)
print(dic2)                #dict类型 

用于文件写读:dump、load

dic = {(1,2):'oldboy',1:True,'set':{1,2,3}}
f = open('pick序列化',mode='wb')
pickle.dump(dic,f)
f.close()
with open('pick序列化',mode='wb') as f1:
    pickle.dump(dic,f1)

3.9 os模块

os.getcwd()        # 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname")  改变当前脚本工作目录;相当于shell下cd  **
os.curdir  返回当前目录: ('.')  **
os.pardir  获取当前目录的父目录字符串名:('..') **

和文件夹相关

os.makedirs('dirname1/dirname2')    #递归生成目录  ***
os.removedirs('dirname1')            #递归删除目录(目录里没有文件(为空)才可以删除)
os.mkdir('绝对路径/相对路径')             #创建一个文件夹 ***
os.rmdir('绝对路径/相对路径')          #删除文件夹***
os.listdir('dirname')                $列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表打印

和文件相关

os.remove()  $删除一个文件  ***
os.rename("oldname","newname")  $重命名文件/目录  ***
os.stat('path/filename')  获取文件/目录信息 **

path系列,和路径相关

os.path.abspath(path) $返回path规范化的绝对路径  ***
os.path.split(path)   #将path分割成目录和文件名二元组返回 ***
os.path.dirname('E:\Python项目')# E:\        获取父级目录
os.path.dirname(os.path.dirname(__file__))#获取父级目录的父级目录 :获取爷爷级目录
os.path.basename('E:\Python项目')#Python项目  返回文件名
os.path.exists(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('D:','s23','day20','随便')#路径拼接,第一个绝对路径之前的参数将被忽略 ***
os.path.getatime(path)  #返回path所指向的文件或者目录的最后访问时间  **
os.path.getmtime(path)  #返回path所指向的文件或者目录的最后修改时间  **
os.path.getsize(path)   #返回path的大小 ***
print(__file__)         $动态获取文件的绝对路径

4.0sys模块

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

4.1 hashlib模块

普通加密

import hashlib
md5 = hashlib.md5()
md5.update('要加密的字符串'.encode('utf-8'))
print(md5.hexdigest())

加盐加密

  • 固定的盐

    import hashlib md5=hashlib.md5('盐'.encode('utf-8')) md5.update('要加密的字符串'.encode('utf-8')) print(md5.hexdigest())

  • 动态的盐

    username = '太白金星666' ret = hashlib.md5(username[::2].encode('utf-8')) # 针对于每个账户,每个账户的盐都不一样 ret.update('a'.encode('utf-8')) print(ret.hexdigest())

文件的一致性校验

def md5_file(path):
    ret = hashlib.md5()
    with open(path,mode='rb') as f1:
        while 1:
            content = f1.read(1024)
            if content:
                ret.update(content)
            else:
                return ret.hexdigest()
print(md5_file(r'E:\Python项目\python-3.7.4rc1-embed-win32.zip'))

4.2time 模块

#导入时间模块
>>>import time

#时间戳
>>>time.time()
1500875844.800804

#时间字符串
>>>time.strftime("%Y-%m-%d %X")
'2017-07-24 13:54:37'
>>>time.strftime("%Y-%m-%d %H-%M-%S")
'2017-07-24 13-55-04'

#时间元组:localtime将一个时间戳转换为当前时区的struct_time
time.localtime()
time.struct_time(tm_year=2017, tm_mon=7, tm_mday=24,
          tm_hour=13, tm_min=59, tm_sec=37, 
                 tm_wday=0, tm_yday=205, tm_isdst=0)

4.3random模块

>>> import random
#随机小数
>>> random.random()      # 大于0且小于1之间的小数
0.7664338663654585
>>> random.uniform(1,3) #大于1小于3的小数
1.6270147180533838
#恒富:发红包

#随机整数
>>> random.randint(1,5)  # 大于等于1且小于等于5之间的整数
>>> random.randrange(1,10,2) # 大于等于1且小于10之间的奇数


#随机选择一个返回
>>> random.choice([1,'23',[4,5]])  # #1或者23或者[4,5]
#随机选择多个返回,返回的个数为函数的第二个参数
>>> random.sample([1,'23',[4,5]],2) # #列表元素任意2个组合
[[4, 5], '23']


#打乱列表顺序
>>> item=[1,3,5,7,9]
>>> random.shuffle(item) # 打乱次序
>>> item
[5, 1, 3, 7, 9]
>>> random.shuffle(item)
>>> item
[5, 9, 7, 1, 3]
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
3年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
Wesley13 Wesley13
3年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Stella981 Stella981
3年前
Gson之实例五
前面四篇博客基本上可以满足我们处理的绝大多数需求,但有时项目中对json有特殊的格式规定.比如下面的json串解析:{"tableName":"students","tableData":{"id":1,"name":"李坤","birthDay":"Jun 22, 2012 9:54:49 PM"},{"id":2,"name":"曹贵生"
Wesley13 Wesley13
3年前
unity将 -u4E00 这种 编码 转汉字 方法
 unity中直接使用 JsonMapper.ToJson(对象),取到的字符串,里面汉字可能是\\u4E00类似这种其实也不用转,服务器会通过类似fastjson发序列化的方式,将json转对象,获取对象的值就是中文但是有时服务器要求将传参中字符串中类似\\u4E00这种转汉字,就需要下面 publ