03序列化模块

04加密模块

05 os sys 模块

06 collections 模块

# 03 序列化模块

# 网络传输数据:字节 bytes# 文件写入内容:bytes , str

# dic = {'city':'柳州','sport':['篮球','滑板','游戏']}# s1 = str(dic)# print(s1,type(s1))# print(dic)

# b1 = s1.encode('utf-8')# print(b1,type(b1))# s2 = b1.decode('utf-8')# print(s2,type(s2))# # s3 = dict(s2)##无法转# dic1 = eval(s2)# print(dic1,type(dic1))

# 1 以上的eval 不安全最好不要用# 现在需要一个功能:将数据 转化成可以通过网络传出的bytes# 将数据(数据结构)  ---> 特殊的字符串(可以用于网络传输)  序列化过程# 将这个特殊的字符串 ----> 转化成原来的数据结构  反序列化过程

# python给咱们提供的序列化模块

import json  #序列化模块,所有语言通用的一种标准(数据转化格式             #str int bool dict list tuple None

import pickle  #序列化模块,只支持python语言之间的互相传输               #所有数据类型,对象都可以进行网络传递               #写入文件时可以写入多个

import shelve  #序列化模块,只支持python语言,与文件相关

#json# 第一队方法:dumps loads 与网络传输相关# dic = {'city':'柳州','sport':['篮球','滑板','游戏']}# s = json.dumps(dic,ensure_ascii=False)  #序列化过程# print(dic,type(dic))  #{'city': '柳州', 'sport': ['篮球', '滑板', '游戏']} <class 'dict'># print(s,type(s))  #{"city": "柳州", "sport": ["篮球", "滑板", "游戏"]} <class 'str'>

# dic1 = json.loads(s)  #反序列化过程# print(dic1,type(dic1))  #{'city': '柳州', 'sport': ['篮球', '滑板', '游戏']} <class 'dict'>

# 第二对 dump load 与文件相关dic = {'city':'柳州','sport':['篮球','滑板','游戏']}# with open('序列化',encoding='utf-8',mode='w') as f1:#     json.dump(dic,f1,ensure_ascii=False)  #序列化过程

# with open('序列化',encoding='utf-8') as f2:#     ret = json.load(f2)# print(ret,type(ret))

#test  #不能str--dict()-->dict

# dic = str(dic)  #不能str--dict()-->dict# print(dic,type(dic))# dic = dict(dic)# print(dic,type(dic))

# with open('test',encoding='utf-8',mode='w') as f1:#     f1.write(dic)  #无法写入,报错:TypeError: write() argument must be str, not dict                     #只能写入str

# with open('test',encoding='utf-8',mode='w') as f1:#     dic = str(dic)#     f1.write(dic)# with open('test',encoding='utf-8') as f2:#     s = f2.read()# print(s,type(s))  #{'city': '柳州', 'sport': ['篮球', '滑板', '游戏']} <class 'str'># s = dict(s)  ##不能str--dict()-->dict# print(s,type(s))    #

# 参数讲解:# dic = {'name': "太白金星",#        'hobby_list': ['戒烟', '烫不了头', '戒酒'],#        'age': 18,#        'money': '1个亿'}# print(dic)# s = json.dumps(dic,ensure_ascii=False,sort_keys=True,separators=('|',','))  # 序列化过程# sort_keys 按键排序0# ensure_ascii=False 显示中文# separators=('|',',') 设置分隔符 没有意义# print(s)# 讨论json  与bytes 的区别# bytes 只能操作str  用于网络传输# json 可以操作 str int  bool dict list(tuple) None 用于网络传入,写入文件

# 通过json将多个字典写入一个文件# 如果用dump load 一个文件只能写入一个数据结构# dic1 = {'name': '春哥'}# dic2 = {'name': '子伍'}# dic3 = {'name': '王子'}# with open('多个字典.json', encoding='utf-8', mode='w') as f1:#        json.dump(dic1,f1)#        f1.write('\n')#        json.dump(dic2,f1)#        f1.write('\n')#        json.dump(dic3,f1)#        f1.write('\n')

# with open('多个字典.json', encoding='utf-8',) as f1:#        ret1 = json.load(f1)#        ret2 = json.load(f1)#        ret3 = json.load(f1)# print(ret1,ret2,ret3)# dic1 = {'name': '春哥'}# # dic2 = {'name': '子伍'}# # dic3 = {'name': '王子'}# # with open('多个字典.json',encoding='utf-8',mode='w') as f1:# #        f1.write(json.dumps(dic1) + '\n')# #        f1.write(json.dumps(dic2) + '\n')# #        f1.write(json.dumps(dic3) + '\n')

# with open('多个字典.json',encoding='utf-8') as f2:# #        for line in f2:# #               print(json.loads(line))

# 总结:# dumps loads 用于网络传输 和 多个数据写入文件# dump load 只能用于一个数据结构写入文件

# 坑:# dic = {1: 'alex'}# ret = json.dumps(dic)# print(ret)# print(json.loads(ret))  #1变成'1'
# pickleimport pickle# dumps loads 用于网络传输 :将数据结构 ----> 转化成bytes# dic = {'name': "太白金星",#        'hobby_list': ['戒烟', '烫不了头', '戒酒'],#        'age': 18,#        'money': '1个亿'}# s1 = pickle.dumps(dic)# print(s1)  #bytes# dic2 = pickle.loads(s1)# print(dic2,type(dic2))# dic = {'name': "太白金星",#        'hobby_list': ['戒烟', '烫不了头', '戒酒'],#        'age': 18,#        'money': '1个亿'}# with open('p1.pickle',mode='wb') as f1:#     pickle.dump(dic,f1)# # with open('p1.pickle',mode='rb') as f2:#     ret = pickle.load(f2)# print(ret,type(ret))
# 利用dump load 将多个数据写入文件#dic1 = {'name': '春哥'}#dic2 = {'name': '子伍'}#dic3 = {'name': '王子'}

# with open('p2.pickle',mode='wb') as f1:#     pickle.dump(dic1,f1)#     pickle.dump(dic2,f1)#     pickle.dump(dic3,f1)

# with open('p2.pickle',mode='rb') as f1:#     ret1 = pickle.load(f1)#     ret2 = pickle.load(f1)#     ret3 = pickle.load(f1)# print(ret1,ret2,ret3)

# def func():#     print(666)## with open('p3.pickle',mode='wb') as f1:# #     pickle.dump(func,f1)

# with open('p3.pickle',mode='rb') as f1:# #     ret = pickle.load(f1)# # ret()

import shelve# f = shelve.open('shelve_file')# f['key'] = {'int':10, 'float':9.5, 'string':'Sample data'}  #直接对文件句柄操作,就可以存入数据# f.close()# 给文件写入一个字典:{'key':{'int':10, 'float':9.5, 'string':'Sample data'}}

# f = shelve.open('shelve_file')# print(f['key'])# f.close()

# import shelve# f1 = shelve.open('shelve_file',writeback=True)# print(f1['key'])# f1['key']['new_value'] = 'this was not here before'# f1.close()

# f1 = shelve.open('shelve_file')# print(f1['key'])# f1.close()# writeback=True 如果相对shelve文件进行修改,必须要添加这个参数

# 04 加密模块

# 加密模块 摘要算法 一堆加密算法的集合体import hashlib# 给密码加密。# 文件的校验。

# hashlib: 将str类型 通过算法 -----> 一串等长度的数字。# 1,不同的字符串 转化成数字肯定不同。# 2,相同的字符串即使在不同的计算机上只要使用相同的加密方式 转化成的数字一定相同。# 3,hashlib加密不可逆,不能破解。

import hashlib# md5 加密# ret = hashlib.md5()# ret.update('好123'.encode('utf-8'))# print(ret.hexdigest())

# 加盐# 让你的密码更复杂。# ret = hashlib.md5('老男孩教育'.encode('utf-8'))# # ret.update('123456'.encode('utf-8'))# # print(ret.hexdigest())

# 动态的盐# username = input('请输入用户名:')# ret = hashlib.md5(username[::2].encode('utf-8'))# ret.update('123456'.encode('utf-8'))# print(ret.hexdigest())

# md5 加密效率快,通用,安全性相对差# sha系列,算法更好 安全性高,效率低,耗时长

import hashlib# ret = hashlib.sha1()# ret.update('gjfds;gfjdgfkdg;lfdkg;fdlgk;fldgk;fldg'.encode('utf-8'))# print(ret.hexdigest())

# ret = hashlib.sha512()  #更复杂# ret.update('gjfds;gfjdgfkdg;lfdkg;fdlgk;fldgk;fldg'.encode('utf-8'))# print(ret.hexdigest())

# 文件校验。

# 文件较小用下面代码。# def check_md5(file):#     ret = hashlib.md5()#     with open(file,mode='rb') as f1:#         ret.update(f1.read())#         return ret.hexdigest()# print(check_md5('文件校验1'))# print(check_md5('文件校验2'))

# ret = hashlib.md5()# ret.update('老男孩教育是最好的培训学校'.encode('utf-8'))# print(ret.hexdigest())  # b549bba39c1e6fd58865b2ba61a3bdff

# ret = hashlib.md5()# ret.update('老男孩教育'.encode('utf-8'))# ret.update('是最好的'.encode('utf-8'))# ret.update('培训'.encode('utf-8'))# ret.update('学校'.encode('utf-8'))# print(ret.hexdigest())  # b549bba39c1e6fd58865b2ba61a3bdff

# 大文件的校验:# def check_md5(file):#     ret = hashlib.md5()#     with open(file,mode='rb') as f1:#         while 1:#             content = f1.read(1024)  #每次读1024#             if content:  #                 ret.update(content)#             else:#                 break#         return ret.hexdigest()

# print(check_md5('文件校验1'))# print(check_md5('文件校验2'))
# def check_md5(file):#     ret = hashlib.md5()#     with open(file,mode='rb') as f1:#         for line in f1:#             ret.update(line)#         return ret.hexdigest()

# print(check_md5('文件'))

# 05 os sys模块

import os# 工作目录,父级目录,当前目录,此文件从属的文件夹的路径

# 获取当前目录# print(os.getcwd()) # D:\python骑士计划3期\day14  ***# os.chdir('d:\\')  # 切换工作目录# print(os.getcwd())# print(os.curdir)# print(os.pardir)

# 例题:# os.chdir(os.pardir)# print(os.getcwd())# print()

# 和文件夹相关# os.mkdir('文件夹1')  # 一次和创建一个文件夹  **

# os.mkdir('文件夹1\文件夹2')# os.rmdir('文件夹1\文件夹2') # 一次删除一个# os.makedirs('文件夹a\文件夹b\文件夹c\文件夹d')  # 递归创建文件夹  ***# os.removedirs('文件夹a\文件夹b\文件夹c\文件夹d')  # 递归删除检测出有文件则停止删除# print(os.listdir('D:\python骑士计划3期\day14 '))  #**

# 和文件相关:# os.remove('os模块练习')  # ***# os.rename('os模块','new os')  # ***# print(os.stat(r'D:\python骑士计划3期\day14\05 os sys模块.py'))

# 操作系统差异相关# print(os.sep) # 输出操作系统特定的路径分隔符# print(repr(os.linesep))# print(os.pathsep)# print(os.name)

# 执行系统命令相关# print(os.system('dir'))# print(os.popen('dir').read())# print(os.environ)

# 路经相关  ***# print(os.path.abspath(__file__))  # 获取绝对路径# print(os.path.abspath('05 os sys模块.py'))  # 获取绝对路径# print(os.path.split(os.path.abspath(__file__))) #  将path分割成目录和文件名二元组返回# ('D:\\python骑士计划3期\\day14', '05 os sys模块.py')# print(os.path.basename(os.path.abspath(__file__)))  # 将文件名返回# print(os.path.exists(__file__)) # 判断路径是否存在# print(os.path.abspath(__file__))# print(os.path.isabs('05 os sys模块.py'))  # False# print(os.path.isfile('barry.json'))  # 判断此文件是否存在  ***# print(os.getcwd())  # D:\python骑士计划3期\day14# path = os.path.join(os.getcwd(), '05 os sys模块.py')  ***# print(path)# print(os.path.getatime('barry.json'))  # 返回path所指向的文件或者目录的最后访问时间# print(os.path.getsize(__file__))  # 返回你的文件大小

# logfile_name = 'all2.log'  # log文件名

# logfile_dir = os.path.dirname(os.path.abspath(__file__))  # log文件的目录# # print(logfile_dir)

# # 如果不存在定义的日志目录就创建一个# if not os.path.isdir(logfile_dir):#     os.mkdir(logfile_dir)

# # # log文件的全路径# logfile_path = os.path.join(logfile_dir, logfile_name)

# sysimport sys# print(sys.argv)# print(666)# sys.exit('意外中断....')# print(666)# print(sys.version)  # 获取Python解释程序的版本信息# # print(sys.platform)

# import sys# try:#     sys.exit('意外中断....')# except SystemExit as e:#     print(e)

# 06 collections模块

# 1 namedtuple# from collections import namedtuple# point = namedtuple('point',['x','y'])# p = point(1,2)# print(p)# print(p[0])# print(p.x)# print(p.x + p.y)

# dequefrom collections import deque# q = deque(['a','b','c'])# print(q)# 从右边增加值# q.append('x')# q.append('y')# # 从右边删除值# q.pop()# q.pop()# 从左边增值# q.appendleft('x')# q.appendleft('y')# # 从左边删除# q.popleft()# q.popleft()# print(q)

# defaultdictfrom collections import defaultdict# values = [11, 22, 33, 44, 55, 77, 88, 99, 90]# my_dict = defaultdict(list)# my_dict['key1']# my_dict['key2']# my_dict['key3']# print(my_dict)# for val in values:#     if val > 66:#         my_dict['key1'].append(val)#     else:#         my_dict['key2'].append(val)# print(my_dict)# 构建一个字典;字典的key 从1~100,对应的值都是666# {1:666,2:666,3:666......}# dic = dict.fromkeys(range(1,101),666)# print(dic)

# print({key:666 for key in range(1,101)})# def func():#     return 666# my_dict = defaultdict(func)# for i in range(1,101):#     my_dict[i]# print(my_dict)#from collections import Counter# s1 = '电脑电脑sldfjslffdsaf'# s1 = ['电脑','电脑','电脑','电脑','书']# c = Counter(s1)# print(c)# print(c['f'])# print(c['d'])# print(dict(c))

day15_python_1124的更多相关文章

随机推荐

  1. MySQL Backup mysqldump备份流程学习

    我们都知道MySQL逻辑备份工具mysqldump可以保证备份数据的一致性,但是它是怎么保持一致性的? 本文不讨论mysqldump具体的选项和用法,一直对mysqldump的工作机制梳理的不太清楚, ...

  2. 与数论的厮守01:素数的测试——Miller Rabin

    看一个数是否为质数,我们通常会用那个O(√N)的算法来做,那个算法叫试除法.然而当这个数非常大的时候,这个高增长率的时间复杂度就不够这个数跑了. 为了解决这个问题,我们先来看看费马小定理:若n为素数, ...

  3. 栈ADT

    栈 栈是限制插入和删除只能在同一位置的表,这一位置称为栈顶(top),也可能称为LIFO表 对于空栈的pop(弹栈)操作是一个ADT错误,但是若是push(压栈)时空间超限并不是ADT错误 实现:基于 ...

  4. 百度富文本Ueditor编辑器的使用

    往在web开发的时候,尤其是在网站开发后台管理系统的时候经常会使用到富文本编辑器,这里我们来使用百度提供的富文本编辑器UEditor,以提高我们的开发效率 UEditor官网下载地址:https:// ...

  5. db2常见错误代码及原因

    sqlcode sqlstate 说明000 00000 SQL语句成功完成01xxx SQL语句成功完成,但是有警告+012 01545 未限定的列名被解释为一个有相互关系的引用+098 01568 ...

  6. python-17

    # 列表生成式 a = [x*2 for x in range(10)] # 这两个变量必须一致 print(a) #列表 元组的高级赋值办法 b,c = [",6] # python的垃圾 ...

  7. 【转】Jira插件安装

    一.Jira插件列表(可以将下面免费插件直接下载,然后登陆jira,在"插件管理"->"上传插件",将下载后的免费插件直接进行上传安装即可) 序号 插件名 ...

  8. 利用ueditor保存到mysql数据库时出现乱码

    首先反复检查页面的字符编码,发现使用的都是 utf-8,再次检查数据库编码格式也用的是UTF-8.用format函数进行格式化,还是不起作用,最用把出现乱码的字段的数据类型由BLOB改成MEDIUMT ...

  9. Python xml模块

    xml模块 自己创建xml文档 import xml.etree.cElementTree as ET new_xml = ET.Element("personinfolist") ...

  10. [JSONObject/JSONArray] - 定制的JSON格式返回

    当前开发的程序中.因为抛弃了jsp的渲染,改为thymeleaf,并在比较厉害的前端进行数据json的渲染无误后,得出此json数据返回. 以往的Map<String,Object>返回j ...