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 文章目录 通配符 字符范围 ` ...
随机推荐
- R语言中abline和lines的区别
函数lines()其作用是在已有图上加线,命令为lines(x,y),其功能相当于plot(x,y,type="1")函数abline()可以在图上加直线,其使用方法有四种格式.( ...
- C++ 语言操作符的优先级
cppreference.com -> C++ 操作符优先级 C++ 操作符优先级 优先级 操作符 1 () [] -> . :: ! ~ ++ ...
- 分布式计算开源框架Hadoop入门实践(三)
Hadoop基本流程 一个图片太大了,只好分割成为两部分.根据流程图来说一下具体一个任务执行的情况. 在分布式环境中客户端创建任务并提交. InputFormat做Map前的预处理,主要负责以下工作: ...
- Linux centos7 安装 keepalived-2.0.6
1.下载(版本:2.0.6) cd /home/install/ wget http://124.205.69.170/files/1255000006EF2AA1/www.keepalived.or ...
- python中的值传递和引用传递
Python中的变量是没有类型的,我们可以把它看做一个(*void)类型的指针,变量是可以指向任何对象的,而对象才是有类型的. Python中的对象有可变对象(number,string,tuple等 ...
- 学会Retrofit+OkHttp+RxAndroid三剑客的使用,让自己紧跟Android潮流的步伐
http://blog.csdn.net/iamzgx/article/details/51607387 概括 在上一篇博客android网络框架OkHttp之get请求(源码初识) 讲解了OkHtt ...
- Linux 基础一---操作系统&常用命令
UNIX是一个计算机操作系统,一个用来协调.管理和控制计算机硬件和软件资源的控制程序. 1.UNIX操作系统的特点:多用户和多任务: a) 多用户表示在同一时刻可以有多个用户同时使用UNIX操作系统而 ...
- node做验证码
使用了ccap插件 1.安装: 通用方法:npm install ccap 2. cnst ccap= require('ccap')({ width: 128, height: 40, offset ...
- java.net.UnknownHostException异常处理
1.问题描述 最近迁移环境,在Linux系统下部署Java产品的应用,后台报出如下异常,系统报找不到名为“xxx-houtai1”的主机: 1 java.net.UnknownHostExceptio ...
- Linux学习笔记001——win下安装Linux虚拟机
我研二之前算是一个纯粹的计算机小白,因为某些原因开始接触了计算机方面的知识. Linux系统也就是前几个月才听说,因某些需求需要在Linux环境下运行.纯的Linux系统不太现实, 所以在他人帮助和自 ...