Head First Python-Python中与文件相关的操作-读、处理、写
最近在看head first python,前面也写了一些笔记,但是基本上没有涉及到一些完整的代码,现在将书中的文件相关操作的代码整理,供以后参考。
主要分为两大部分,读取文件、处理异常,处理文件、存储文件。
0,处理文件
首先介绍后面将会用到的知识点,格式化输出列表;
如果一个列表嵌套多层列表,使用一般的方法来打印无法打印出嵌套的列表。下面的方法只能打印出一层,如果想打印多层怎么办?
movies=['aWith a ','bpopulation of 1060', ['cthe village','dis carpeted with ','eazalea blossoms', ['fwith fast-flowing rivers ','gscattered guesthouses','hadding strokes and splashes to ','ithe natural canvas.']]] print(movies)
def printList(movies):
for i in movies:
print(i)
print(printList(movies))
下面通过给printList增加参数来控制格式化输出(intent控制是否需要格式化,t用来控制指标表符个数):
movies=['aWith a ','bpopulation of 1060', ['cthe village','dis carpeted with ','eazalea blossoms', ['fwith fast-flowing rivers ','gscattered guesthouses','hadding strokes and splashes to ','ithe natural canvas.']]] print(movies)#1 def printList(movies,intent=False,t=0):
for i in movies:
if isinstance(i , list): #isinstance检查一个标识符是否指示某个指定类型的数据对象
# for j in i:
printList(i,intent,t+1)#增加一层嵌套制表符加1
else:
if intent:
for j in range(t):
print("\t", end='')
print(i) print(printList(movies,False))#2
print(printList(movies,True,0))#3
输出如下:
1,读取文件
pyhont中使用open来打开一个文件:
import os
if os.path.exists('./temp/sketch.txt'):
data =open('./temp/sketch.txt')
print(data.readline(),end='')
print(data.readline(),end='')
data.seek(0)
for each_line in data:
if not each_line.find(':') == -1:
(role,line_spoken)=each_line.split(':',1)
print(role,end='')
print(' said: ',end='')
print(line_spoken,end='')
data.close()
else:
print('file not exists!!!')
2,处理异常
如果要读取的文件不存在咋办?
data =open('./temp/sketch.txt')
print(data.readline(),end='')
print(data.readline(),end='')
data.seek(0)
for each_line in data:
try:
(role,line_spoken)=each_line.split(':',1)
print(role,end='')
print(' said: ',end='')
print(line_spoken,end='')
except ValueError:
pass
data.close()
我们知道,打开一个文件,读取或者写入结束后要进行关闭。
3,存储文件
保存一个文件:
(1)使用print(),print函数的参数file来定义输出对象,默认输出到屏幕:
man = []
other = []
try:
data=open('./data/sketch.txt')
for each_line in data:
try:
(role,line_spoken)=each_line.split(':',1)
line_spoken=line_spoken.strip()
if role=='Man':
man.append(line_spoken)
elif role=='Other Man':
other.append(line_spoken)
except ValueError:
pass
data.close()
except IOError as err:
print("the datafile is missing..."+str(err)) try:
with open('./temp/man_data.txt','a') as man_data:
print(man, file=man_data)
with open('./temp/other_data.txt','a') as other_data:
print(other, file=other_data)
except IOError as err:
print ('ERROR: '+str(err))
(2)使用pickle(),pickle函数有存文件dump()和读文件load()两个方法,将文件以二进制流的形式存储到本地:
import pickle
import sys def print_lol(the_list,indent=False,level=0,lol=sys.stdout):
for each_item in the_list:
if isinstance(each_item,list):
print_lol(each_item,indent,level+1,lol)
else:
if indent:
for tab_stop in range(level):
print('\t',end='',file=lol)
print(each_item,file=lol) man = []
other = []
try:
data=open('./data/sketch.txt')
for each_line in data:
try:
(role,line_spoken)=each_line.split(':',1)
line_spoken=line_spoken.strip()
if role=='Man':
man.append(line_spoken)
elif role=='Other Man':
other.append(line_spoken)
except ValueError:
pass
data.close()
except IOError as err:
print("the datafile is missing..."+str(err))
#存文件
try:
with open('./temp/man_data.dat','wb') as man_data:
pickle.dump(man,man_data)
with open('./temp/other_data.dat','wb') as other_data:
pickle.dump(other,other_data)
except pickle.PickleError as err:
print ('ERROR: '+str(err))
#读文件
new_man=[]
try:
with open('./temp/man_data.dat','rb') as new_man_file:
new_man=pickle.load(new_man_file)
except IOError as err:
print('IOError: '+str(err))
except pickle.PickleError as perr:
print('PickError: '+ str(perr)) print_lol(new_man)
print(new_man[0])
print(new_man[-1])
代码来源:head first python
Head First Python-Python中与文件相关的操作-读、处理、写的更多相关文章
- Python中的文件和目录操作实现
Python中的文件和目录操作实现 对于文件和目录的处理,虽然可以通过操作系统命令来完成,但是Python语言为了便于开发人员以编程的方式处理相关工作,提供了许多处理文件和目录的内置函数.重要的是,这 ...
- C++ STL中Map的相关排序操作:按Key排序和按Value排序 - 编程小径 - 博客频道 - CSDN.NET
C++ STL中Map的相关排序操作:按Key排序和按Value排序 - 编程小径 - 博客频道 - CSDN.NET C++ STL中Map的相关排序操作:按Key排序和按Value排序 分类: C ...
- python中 对文件的读写操作 以及如何边写入 边保存flush()
转自:https://blog.csdn.net/t8116189520/article/details/78854708 首先 python中打开文件大致常用的几类如下: 1.写入文件write # ...
- 洗礼灵魂,修炼python(19)--文件I/O操作,linecache,fileinput模块
文件I/O操作 1.什么是文件I/O操作 首先I/O(input/output),即输入/输出端口,然后文件,大家应该都是是什么,一个数据,一个txt或者html文档就是一个文件.文件操作就是对文件进 ...
- linux中Makefile文件相关内容
第一章.概述什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional(专业)的程序员,m ...
- python文本操作—读、写
文本文件存储的数据有很多,我们需要把这些文本里的内容读出来,然后在浏览器上面显示. 1.读取整个文本文件 格式: with open(路径) as 变量: 变量.read() 关键字with作用:在不 ...
- PHP文件相关的操作函数——目录操作
1.有关文件类型的函数 PHP是以UNIX的文件系统为模型的,因此在Windows系统中我们只能获得“file”.“dir”或者“unknown”三种文件类型.而在UNIX系统中,我们可以获得“blo ...
- Sharepoint中有关文件夹的操作
1.GetItemsWithUniquePermissions根据返回数量和是否返回文件夹获取唯一权限的列表项集合 对于SharePoint对象模型中SPList的GetItemsWithUnique ...
- R语言文件相关的操作
1. 文件系统介绍 R语言对文件系统的操作,包括文件操作和目录操作,函数API都定义在base包中. 2. 目录操作 2.1 查看目录 查看当前目录下的子目录. # 启动R程序 ~ R # 当前的目录 ...
随机推荐
- LeetCode第十一题-可以装最多水的容器
Container With Most Water 问题简介:通过一个给定数组,找出最大的矩形面积 问题详解:给定一个数组,包含n个非负整数a1,a2,…,an,其中每个表示坐标(i,ai)处的点,绘 ...
- O2O、B2B、C2C(通俗讲解)
你在地摊买东西,C2C你去超市买东西,B2C超市找经销商进货,B2B超市出租柜台给经销商卖东西,B2B2C你在网上下载个优惠券去KFC消费,O2O 一:O2O 1.概念: O2O即Online To ...
- 学习pano2vr制作html5全景笔记
demo截图: demo下载: 百度网盘:http://pan.baidu.com/s/1o8yBwIA 密码:nf62(启服务端查看); 我制作是全屏定点360的全景页面,使用pano2vr软件制作 ...
- maven历史版本下载地址
http://archive.apache.org/dist/maven/maven-3/
- 有道云笔记Markdown上传本地图片的方法
有道云笔记截图&保存 方法有多种,例如:开通有道云笔记VIP会员.先将图片文件上传到有道云笔记后使用图片的分享链接.说到底还是使用的 Markdown 的图片功能 ![图片名称](图片链接 ...
- vue+element ui 表格自定义样式溢出隐藏
样式 .hoveTitle { text-align: left; width: 140px; overflow: hidden; text-overflow: ellipsis; white-spa ...
- numpy array的复制-【老鱼学numpy】
对象的引用 看例子: a = np.array([0, 1, 2, 3]) b = a a[0] = 5 print("b=", b) # 判断a和b是否是同样的地址 print( ...
- SQL 性能优化 总结
SQL 性能优化 总结 (1)选择最有效率的表名顺序(只在基于规则的优化器中有效): ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,FROM子句中写在最后的表(基础表 driving ...
- Jupyter-notebook 不自动打开浏览器解决办法
我的系统是Manjaro Linux, 一直以来,我使用jupyter-notebook的办法都是使用命令sudo jupyer-notebook --allow-root,然后手动复制粘贴URLS到 ...
- P1516 青蛙的约会
P1516 青蛙的约会x+mt-p1L=y+nt-p2L(m-n)t+L(p2-p1)=y-x令p=p2-p1(m-n)t+Lp=y-x然后套扩欧就完事了 #include<iostream&g ...