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 # 当前的目录 ...
随机推荐
- 【原创】大数据基础之Oozie(2)使用
命令行 $ oozie help 1 导出环境变量 $ export OOZIE_URL=http://oozie_server:11000/oozie 否则都需要增加 -oozie 参数,比如 $ ...
- 【原创】大叔经验分享(43)logstash设置jdbc_default_timezone后报错
logstash6.6.0-6.6.2版本使用jdbc input plugin时如果设置了jdbc_default_timezone,会报错: { 2012 rufus-scheduler inte ...
- spring MVC如何获取session传值到前台
Session简单介绍 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务器程 ...
- highcharts的dataLabels如何去处阴影
问题: 在使用highcharts生成的图标中dataLabels是有阴影的,通常是影响美观,那么如何去除阴影呢? 原因:是因为highcharts将dataLabels生成的标签是tspan,里面有 ...
- 【转】win10哪个版本最好用,推荐win10企业版LTSC
https://msdn.itellyou.cn/ win10企业版LTSC又被称为win10企业版2019长期服务版本,这个版本小编认为是目前最好用的win10版本,在win10企业版2016长期服 ...
- 提取C3D视频特征(官方文档&实践)
C3D Introduction 卷积神经网络(CNN)近年被广泛应用于计算机视觉中,包括分类.检测.分割等任务.这些任务一般都是针对图像进行的,使用的是二维卷积(即卷积核的维度为二维).而基于视频的 ...
- drop、truncate和delete的区别
TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同:二者均删除表中的全部行.但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源 ...
- Python Basic 01.Basic
01.variable ''' 변수(variable) - 자료(data)를 임시(휘발성) 저장하는 역할 - 실제 자료가 아닌 자료의 주소를 저장한다.(참조변수) ''' # 1. 변수 ...
- Django模型初识
模型层(what.why.how) 模型的相关配置
- xml格式转成json格式,使用Python
import xml.etree.ElementTree root=xml.etree.ElementTree.parse('testXml.xml') book=root.findall('pers ...