python 之 序列化与反序列化、os模块
6.6 序列化与反序列化
特殊的字符串 , 只有:int / str / list / dict
最外层必须是列表或字典,如果包含字符串,必须是双引号"".
序列化:将Python的值转换为json格式的字符串.
反序列化:将json格式的字符串转换成Python的数据类型.
优点:所有语言通用
缺点:只能序列化基本的数据类型.
6.61 json.dumps
序列化:内存中的数据类型----》转成一种中间格式(字符串)----》存到文件中
import json
with open('db.json','wb') as f:
dic={'name':'egon','age':18}
res=json.dumps(dic) # json格式全都是双引号
print(res,type(res)) # {"name": "egon", "age": 18} <class 'str'>
f.write(res.encode('utf-8'))
6.62 json.loads
反序列化:文件----》读取中间格式(字符串)------》转成内存中数据类型
import json
with open('db.json','r',encoding='utf-8') as f:
data=f.read()
dic=json.loads(data)
print(dic,type(dic)) # {'name': 'egon', 'age': 18} <class 'dict'>
print(dic['name']) # egon
6.63 json.dump
import json
with open('db1.json','wt',encoding='utf-8') as f:
dic={'name':'egon','age':18}
json.dump(dic,f)
6.64 json.load
import json
with open('db1.json','rt',encoding='utf-8') as f:
dic=json.load(f)
print(dic['name']) # egon
6.65 pickle序列化
优点: Python中所有的东西都能被序列化(除socket对象)
缺点: 序列化的内容只有Python认识.
import pickle # pickle.dumps
s={1,2,3,4,}
res=pickle.dumps(s)
print(res,type(res)) # <class 'bytes'> ,转成bytes类型
with open('db.pkl','wb') as f:
f.write(res)
import pickle # pickle.dump
s={1,2,3}
with open('db1.pkl','wb') as f:
pickle.dump(s,f)
6.66 pickle反序列化
with open('db.pkl','rb') as f: # pickle.loads
data=f.read()
print(data)
s=pickle.loads(data)
print(s,type(s)) # {1, 2, 3, 4} <class 'set'>
with open('db1.pkl','rb') as f: #=pickle.load
s=pickle.load(f)
print(s,type(s)) # {1, 2, 3} <class 'set'>
6.7 os模块
os.path系列
os.path.abspath(path) 返回path规范化的绝对路径
import os
file_path=r'a\b\c\d.txt'
print(os.path.abspath(file_path)) #C:\Users\Desktop\a\b\c\d.txtos.path.split(path) 将path分割成目录和文件名二元组返回
res=os.path.split(r'C:\a\b\c\d.txt')
print(res) # ('C:\\a\\b\\c', 'd.txt')
print(res[-1]) # d.txt
print(res[0]) # C:\a\b\cos.path.isabs(path) 如果path是绝对路径,返回True
print(os.path.isabs(r'b/c/d.txt')) # False
os.path.normcase(path) 在Linux和Mac平台上,该函数会原样返回path,在windows平台上会将路径中所有字符转换为小写,并将所有斜杠转换为反斜杠
print(os.path.normcase('C:/Windows\\system32\\') ) # c:\windows\system32\os.path.dirname(path) 返回path的目录 其实就是os.path.split(path)的第一个元素
import os
BASE_DIR=os.path.dirname(os.path.dirname(__file__)) #__file__当前文件地址
print(BASE_DIR) # os.path.dirname() 获取上一级地址路径os.path.normpath( ) 规范化路径,如 .. 和 /
print(os.path.normpath('c://windows\\System32\\../Temp/')) #'c:\\windows\\Temp'
a='/Users/jieli/test1/\\\a1/\\\\aa.py/../..' #/Users/jieli/test1
print(os.path.normpath(a))os.path.join( path1 [ , path2 [ , ... ] ] ) 将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
print(os.path.join('C:\\','a','b','a.txt')) #C:\a\b\a.txt
print(os.path.join('C:\\','a','D:\\','b','a.txt')) #D:\b\a.txt 第一个c:\a被忽略
print(os.path.join('a','b','a.txt')) #a\b\a.txt
res=os.path.normpath(os.path.join(__file__,'..','..'))
print(res) #C:\Users\Desktop\day15\下午os.path.basename(path) 返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素
print(os.path.basename(r'C:\a\b\c\d.txt')) # d.txt
os.path.exists(path) 如果path存在,返回True;如果path不存在,返回False, 只管路径是否存在,不区分文件还是文件夹
print(os.path.exists(r'D:\code\SH_fullstack_s1\day15\下午\json.py')) #True
print(os.path.exists(r'D:\code\SH_fullstack_s1\day15')) #Trueos.path.isfile(path) 如果path是一个存在的文件,返回True。否则返回False
print(os.path.isfile(r'D:\code\SH_fullstack_s1\day15\下午')) #False
os.path.isdir(path) 如果path是一个存在的目录,则返回True。否则返回False
print(os.path.isdir(r'D:\code\SH_fullstack_s1\day15\下午')) #True
os.path.getsize(path) 返回path的大小
res=os.path.getsize(r'D:\code\SH_fullstack_s1\day15\上午\settings.py') # 单位是字节
print(res)
6.71 os路径处理
方式一:推荐使用
import os
import os,sys
possible_topdir = os.path.normpath(os.path.join( os.path.abspath(__file__),
os.pardir, #上一级
os.pardir,
os.pardir
))
sys.path.insert(0,possible_topdir)
方式二:不推荐使用
import os
import os,sys
BASE_DIR=os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
sys.path.insert(0,BASE_DIR)
6.8 包的使用
python 之 序列化与反序列化、os模块的更多相关文章
- python json序列化与反序列化操作
python json序列化与反序列化操作 # dumps() dict-->str 序列化 # loads() str---dict 反序列化 result1 = json.dumps({'a ...
- python的序列化和反序列化以及json
python 的序列化和反序列化用于内存之间的共享,包括服务器和客户端的共享,两个Python程序之间的共享,以及以字符串的形式存储到硬盘中. pyhton 的pickle 可以对Python的各种数 ...
- Python的路径操作(os模块与pathlib模块)
Python的路径操作(os模块与pathlib模块) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.os.path模块(Python 3.4版本之前推荐使用该模块) #!/u ...
- python:序列化与反序列化(json、pickle、shelve)
本节内容 前言 json模块 pickle模块 shelve模块 总结 一.前言 1. 现实需求 每种编程语言都有各自的数据类型,其中面向对象的编程语言还允许开发者自定义数据类型(如:自定义类),Py ...
- python 的序列化和反序列化
什么是序列化?简单来说就是将数据存储到物理内存上的过程叫序列化. 什么是反序列化?将数据从物理内存存储到程序内存的过程叫做反序列化. 下面来看一下python中使用json进行序列化和反序列化的实例d ...
- python 中文件输入输出及os模块对文件系统的操作
整理了一下python 中文件的输入输出及主要介绍一些os模块中对文件系统的操作. 文件输入输出 1.内建函数open(file_name,文件打开模式,通用换行符支持),打开文件返回文件对象. 2. ...
- Python(七)之OS模块
文件系统功能:os模块 python编程时,经常和文件.目录打交道,这是就离不了os模块.os模块包含普遍的操作系统功能,与具体的平台无关.以下列举常用的命令: 目录: os.mkdir('/tmp/ ...
- Python Json序列化与反序列化
在python中,序列化可以理解为:把python的对象编码转换为json格式的字符串,反序列化可以理解为:把json格式字符串解码为python数据对象.在python的标准库中,专门提供了json ...
- Python之文件操作:os模块
Python os 模块提供了一个统一的操作系统接口函数 一.对于系统的操作 1.os.name 当前使用平台 其中 ‘nt’ 是 windows,’posix’ 是linux 或者 unix 2.o ...
随机推荐
- linux 常用shell脚本语句
最近老大让写一个shell脚本,每天从一个固定IP中取到相应文件,所以想写一个简单的shell脚本命令,供大家学习交流.先做一个简单的例子,先看效果吧, 代码如下: #!/bin/sh #定义一个变量 ...
- ajax 异步 跨域上传图片
客户端 <label for="text">名称</label> <input type="text" id="text ...
- 【LeetCode】最大子序和
给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和. 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4], 输出: 6 解释: 连续子数组 ...
- Spring Boot2.0之性能优化
1.JVM参数调优 针对运行效果 吞吐量 初始堆内存与最大堆尽量相同 减少垃圾回收次数 2.扫包优化: 启动优化 默认Tomcat容器改为Undertow Tomcat的吞吐量500 ...
- 解读 CSS 布局之水平垂直居中
对一个元素水平垂直居中,在我们的工作中是会经常遇到的,也是CSS布局中很重要的一部分,本文就来讲讲CSS水平垂直居中的一些方法.由于我们大搜车的日常工作中已经不再需要理会低版本IE,所以本文所贴出的方 ...
- Compiling: main.cpp /bin/sh: g++: not found
Kbuntu用codeblocks编写C程序的时候,编译报错如下: Compiling: main.cpp/bin/sh: g++: not found 解决方法: sudo apt-get inst ...
- Linux学习之路(二)文件处理命令之下
分区格式化: 一块分区想要使用的话,要格式化.格式化主要有两个工作,1,把分区分成等大小的数据块,每个数据块一般为4KB.2在分区之前建一个分区表,给第一个文件建一行相关数据,在分区表里保存了它的io ...
- Proftpd mysql认证配置文档
Proftpd mysql认证配置文档 ver1.0, 2012/09/25 一.下载安装proftp mysql 下载 wget http://cloud.github.com/downloads/ ...
- 机器学习:Selective Search for Object Recognition
今天介绍 IJCV 2013 年的一篇文章,Selective Search for Object Recognition,这个是后面著名的DL架构 R-CNN 的基础,后续介绍 R-CNN 的时候, ...
- SpringBoot 版本升级后报错 Cannot instantiate interface org.springframework.context.ApplicationContextInitializer
本篇博客纯粹讲我遇到这个问题的解决以及思考,如果你想知道解决方法,可以直接看正确解决方案部分.因为是前端写的,所以可能有些明显的内容很容易就看出来了. 首先:升级后更新其他依赖,以及Applicati ...