IO编程、操作文件或目录、序列化、JSON
IO中指Input/Output,即输入和输出;涉及到数据交换的地方,通常是磁盘、网络等,就需要IO接口
1、由于CPU和内存的速度远远高于外设的速度,所以,在IO编程中,存在速度严重不匹配问题。eg:把100M的数据写入磁盘,CPU输出100M的数据只需要0.01秒,可是磁盘接收100M数据可能需要10秒,怎么办呢,有两种办法:
①、CPU等着,也就是程序暂停执行后续代码,等100M数据在10s后写入磁盘,再接着往下执行,这种模式称为同步IO
②、CPU不等待,只是告诉磁盘,"慢慢写,不着急,我接着干别的事了",于是,后续代码可以立刻接着执行,这种模式称为异步IO
很明显,异步IO来编写程序性能会远远高于同步IO,但是异步IO的缺点是编程模型复杂
2、读写文件前,我们必须先了解一下,在磁盘上读写文件的功能都由操作系统提供的,现代操作系统不允许普通的程序直接操作磁盘,所以,读写文件就是请求操作系统打开一个文件对象(文件描述符),然后,通过操作系统提供的接口从这个文件对象中读取数据(读文件),或者吧数据写入这个文件对象(写文件)
①、读文件
读文件的模式打开一个文件对象,使用Python内置的open()函数,传入文件名和标识符:
>>>f=open('User/test.txt','r') r:表示读,这样就成功打开一个文件,如果文件不存在,open()函数会抛出一个IOError的错误,并给出错误码和详细信息
>>>f.read() 可以一次读取全部文件内容,python把内容读到内存,用一个str表示;read(size)方法,每次最多读取size个字节内容,10G内容这种保险(内存不足);readline()每次读一行,配置文件
>>>f.close() 文件使用完毕后,因为文件对象会占用操作系统的资源,并操作系统同一时间能打开的文件数量也是有限的
由于读写文件有可能产生IOError错误,一旦出错,后面f.close()就不会调用:
try:
f=open('/path/to/file','r')
print f.read()
finally:
if f:
f.close()
每次都try...finally..来实现,太繁琐,所以python引入with语句来自动帮我们调用close()方法:这种方法更佳简洁,并不必调用f.close()方法
with open('/path/to/file','r') sa f:
print f.read()
②、写文件
写文件和读文件一样的,唯一区别是调用open()函数时,传入标识符‘w’或'wb',表示写文本文件和写二进制文件
>>>f=open('/User/to/test','w')
>>>f.write('Hlleo ,world')
>>>f.close()
使用with语句写:
with open('/User/to/test','w') as f
f.write('Hlleo ,world')
----------------------------------------------------------------------------------------------------------------------------------------
操作文件和目录
1、 如果要操作文件、目录,可以在命令行下面输入操作系统提供的各种命令来完成;比如,dir、cp等命令
如果要在Python程序中执行这些目录和文件的操作怎么办??其实操作系统提供的命令只是简单地调用了操作系统提供的接口函数,Python内置的os模块也可以直接调用操作系统提供的接口函数
>>>import os
>>>os.name
>>>'posix' 如果是posix,说明系统是Linux、Unix或Mac OS X;如果是nt,就是Windows系统
2、、环境变量:要获取某个环境变量的值,可以调用os.getenv()函数
>>>import os
>>>os.getenv('path')
3、Python中对文件、文件夹操作时经常用到的os模块和shutil模块常用方法
A、得到当前工作目录,即当前python脚本工作的目录路径:os.getcwd() ; os.path.abspath('.') 查看当前目录的绝对目录
B、返回指定目录下的所有文件和目录名:os.remove(‘C:\\Users\\zxq\\Desktop\\total’) 需要写入\\
C、函数用来删除一个文件:os.remove('C:\\Users\\zxq\\Desktop\\total\\test.txt')
D、检验给出的路径是否是一个文件:os.path.isfile('C:\\Users\\zxq\\Desktop\\total\\测试.txt') 返回true、False
E、检验给出的路径是否是一个目录:os.path.isdiir()
F、检验给出的路径是否是真地存在:os.path.exists()
G、获取路径名:os.path.dirname()
H、运行shell命令:os.system()
I、重命名:os.rename(old,new)
J、创建单个目录:os.mkdir('test')
K、修改文件权限与时间戳:os.chmod(file)
L、获取文件大小:os.path.getsize(filename)
4、文件操作方法大全:
A、os.mknod('test')
B、fp=open('test',w) 直接打开一个文件,如果文件不存在则创建文件
O、fp.read([siaze]) size为读取长度,以byte为单位
P、fp.write(str) 把str写到文件中
Q、fp.close() 关闭文件
os.chdir('C:\Users\zxq\Desktop') 切换到指定目录
os.getcwd() 查看当前所在目录
python os.path模块:
---------------------------------------------------------------------------------------------------------------------------------
1、序列化 pickling:把变量从内存中变成可存储或传输的过程中称为序列化。序列化之后,就可以把序列化后的内容写入磁盘或者通过网络传输到别的机器上。
反序列化 unpickling:把变量内容从序列化的对象重新读到内存中
Python提供两个模块来实现序列化:cPickle和pickle。都是一样的区别在于cPickle是用C语言写的,速度快;Pickle是纯python写的,速度慢;用时先尝试导入cpickle,若失败再导入pickle
try:
import cPickle as pickle
exception:
import pickle
eg1 :把一个对象序列化并写入文件
import cPickle as pickle 导入模块
f = open('C:\\Users\\zxq\\Desktop\\a.txt','wb') 直接打开一个文件,如果文件不存在则创建文件
d = dict(name = 'zhu',age = 23,score = 88) 在程序运行过程中,所有变量都是在内存中
pickle.dump(d,f) 直接把对象序列化后写入一个文件;a.txt文件是一些乱七八糟内容,是python保存的对象内部信息
f.close() 关闭文件
eg2:反序列化刚才保存的对象:
f = open('C:\\Users\\zxq\\Desktop\\a.txt','rb')
d = pickle.load(f) 反序列化出对象
f.close()
print d 输出:{'age': 23, 'score': 88, 'name': 'zhu'}
2、JSON:python语言特定的序列化模块是pickle,但如果把序列化搞得更通用、更符合web标准,就可以使用json模块
如果我们要在不同的编程语言之间传递对象,就必须把对象序列化为标准格式,比如XML,当更好的方法是序列化为JSON,因为json表示出来就是一个字符串,可以被所有语言读取,也可以方便地存储到磁盘或者通过网络传输。json不仅是标准格式,并且比XML更快,而且可以直接在web页面中读取,非常方便。
JSON表示的对象就是标准的JavaScript语言的对象,JSON和Python内置的数据类型对应如下:
json类型 Python类型
{} dict
[] list
'string' str
123.56 int\float
true\false True\False
null None
python内置的json模块提供了非常完善的python对象到json格式的转换。如何把python对象变成一个json:
import json
d = dict(name = 'zhu',age = 23,score = 88)
json.dumps(d)输出:{'age': 23, 'score': 88, 'name': 'zhu'}
JSON反序列化为python对象:
>>> json_str = '{"age": 20, "score": 88, "name": "Bob"}'
>>> json.loads(json_str)
{u'age': 20, u'score': 88, u'name': u'Bob'}
IO编程、操作文件或目录、序列化、JSON的更多相关文章
- Python之IO编程——文件读写、StringIO/BytesIO、操作文件和目录、序列化
IO编程 IO在计算机中指Input/Output,也就是输入和输出.由于程序和运行时数据是在内存中驻留,由CPU这个超快的计算核心来执行,涉及到数据交换的地方,通常是磁盘.网络等,就需要IO接口.从 ...
- 【Python】[IO编程]文件读写,StringIO和BytesIO,操作文件和目录,序列化
IO在计算机中指Input/Output,也就是输入和输出. 1.文件读写,1,读文件[使用Python内置函数,open,传入文件名标示符] >>> f = open('/User ...
- Python3 IO编程之操作文件和目录
如果我们要操作文件,目录,可以在命令行下面输入操作系统提供的各种命令来完成.比如ls,cp等命令 如果要在python程序中执行这些目录和文件的操作怎么办?其实操作系统提供的命令指示简单地调用了操作系 ...
- python的I/O编程:文件打开、操作文件和目录、序列化操作
1 文件读写 1.1 打开文件: open(r'D:\text.txt') 1.2 文件模式 值 功能描述 'r' 读模式 'w' 写模式 'a' 追加模式 'b' 二进制模式 '+' 读写模式 1. ...
- IO编程(2)-操作文件和目录
操作文件和目录 如果我们要操作文件.目录,可以在命令行下面输入操作系统提供的各种命令来完成.比如dir.cp等命令. 如果要在Python程序中执行这些目录和文件的操作怎么办?其实操作系统提供的命令只 ...
- Java基础 IO流的文件和目录的五类主要操作
笔记: /** IO流的 文件和目录的操作 * 1.路径需要 需要两个反斜杠 或者一个单斜杠! * 绝对路径:包括盘符在内的完整的路径名! * 相对路径:在当前目录文件下的路径! * 2.File 是 ...
- IO流----操作文件的9种方法代码实现
IO流----操作文件的9种方法代码实现: 1:使用字节流读写数据: 四种方式: method1: 每次读写一个字节,边读边写: /* * 复制文本文件. * * 数据源:从哪里来 ...
- 使用File类操作文件或目录的属性
在学I/O流之前,我先总结一下使用File类操作文件或目录的属性. package com.File; import java.io.File; import java.io.IOException; ...
- (三)linux 学习 --操作文件和目录
The Linux Command Line 读书笔记 - 部分内容来自 http://billie66.github.io/TLCL/book/chap05.html 文章目录 通配符 字符范围 ` ...
随机推荐
- JAVA项目中常用的异常知识点总结
JAVA项目中常用的异常知识点总结 1. java.lang.nullpointerexception这个异常大家肯定都经常遇到,异常的解释是"程序遇上了空指针",简单地说就是调用 ...
- JAVA & C++ 多态
多态,也叫动态绑定. Java: class A { public void f1() { System.out.println("A:f1"); } public void f2 ...
- MySQL数据库(7)_MySQL 数据备份与还原
一.数据备份 1.使用mysqldump命令备份 mysqldump命令将数据库中的数据备份成一个文本文件.表的结构和表中的数据将存储在生成的文本文件中. mysqldump命令的工作原理很简单.它先 ...
- Centos小脚本(sftp)
sftp用户创建,改变属组,家目录 #!/bin/python import os,sys class sftp_user(object): def __init__(self,user,passwd ...
- python之路 正则表达式,模块导入的方法,hashlib加密
一.正则表达式re python中re模块提供了正则表达式相关操作 字符: . 匹配除换行符以外的任意字符 \w 匹配字母或数字或下划线或汉字 \s 匹配任意的空白符 \d 匹配数字 \b 匹配单词的 ...
- Python学习进程(4)运算符
本节主要介绍Python的运算符. (1)Python语言支持的运算符类型: .算术运算符 .比较(关系)运算符 .赋值运算符 .逻辑运算符 .位运算符 .成员运算符 .身份运算符 . ...
- $Android AlarmManager的用法详解
在Android的Alarm机制中,使用AlarmManager可以实现类似闹钟这样的定时任务.在毕业设计项目中要实现定时任务的功能,所以在这里先进行一下梳理. (一)AlarmManager与Bro ...
- git全局忽略
今天在提交一个本地新建的build文件夹内的文件时,sourceTree始终无法找到该文件夹下的任何内容,但是项目中的.gitignore中并没有写/build/配置,于是开始了填坑之路! 首先从表象 ...
- Spring 手动获取request和response
//获取responseHttpServletResponse response = ((ServletRequestAttributes) RequestContextHolder.getReque ...
- 虚构 css 父级选择器
能 CSS 解决的绝不用 JS,这句话又一次故作装逼地说出来还是挺爽的... 比如下拉列表,能用 CSS 的 :focus 就不用 JS 的 .on("focus blur") 能 ...