1.1. 对文件操作基本操作

操作流程:

打开文件,得到文件句柄并赋值给一个变量

通过句柄对文件进行操作

关闭文件

注意pyton中操作的文件是utf8保存的,打开文件时open函数是通过操作系统打开的文件,而win操作系统默认的是gbk编码,所以直接打开会乱码,需要f=open('hello',encoding='utf8'),hello文件如果是gbk保存的,则直接打开即可。

简单的文件介绍

文件一旦定义,就不能修改,只能是重新写入新的文件/覆盖

with open('hhh.txt', 'r') as f:
print(f.read()) # UnicodeDecodeError: 'gbk' codec can't decode byte 0x98 in position 66: illegal multibyte sequence
# 中文是GBK,不能直接转换为bytes,所以报错[Py3中只有bytes和str,所以转换不了bytes,也就转换不了unicode,需要说明的是unicode向下兼容utf-8]
# 打开文件流,以读写的方式 【错误的】
f = open('hhh', 'rw', encoding='utf-8')

附文件操作模式:

注意: w+模式任然会清空文件内容

读的时候永远从光标0开始, 写的时候永远都是从最后开始写,文件不能修改,但是可以复制文件到新的文件里面进行操作【基于内存本来的机制限制】

打开文件流,以w+方式

# 打开文件流,以w+方式
f = open('hhh', 'w+', encoding='utf-8')
# 文件操作,直接操作文件,Python会自动将for作为一个迭代器来输出,用一个选择一个来输出
f.write("how are you") # 写之前清空文件
f.flush()
# f.seek(0) # 写完后光标移动到文件尾部,所以读取不到文件
print(f.read())
# 关闭文件流
f.close()

文件的读操作

只能以一种模式打开  r/w/a/x/t/+   具体参见上图

输出的时候,python里面的光标也会跟着print同步转移,下一次print会打印下一行

# version: python3.2.5
# author: ‘FTL1012
# time: 2017/12/8 12:16 # 打开文件流,以读的方式
f = open('hhh', 'r', encoding='utf-8')
print(f.read(1)) # 打印一个字符
print(f.readline()) # 读取一行
# print(f.readline(5)) # 读取一行中的前5个字符
# print(f.readlines()) # 多行读取,并组成一个列表
# 打印全部文字/字符
file = f.read()
print(file)
# 关闭文件流
f.close()

注意:readlines()读取会返回一个列表,for循环打印的时候,会读取到文本后的换行符,默认会打印出来

f = open('hhh', 'r', encoding='utf-8')
for i in f.readlines():
print(i.strip()) # 默认会打印出来后面的换行符,所以在这里进行了过滤
# 关闭文件流
f.close()

另:# 在特定的行添加 I love U

方案一:直接读取列表
# print(f.readlines()[1].strip()+'I love U')
# print(''.join((f.readlines()[1].strip()+'I love U')))
方案二:自定义变量
# 打开文件流,以读的方式
f = open('hhh', 'r', encoding='utf-8')
# 读取文件
date = f.readlines()
# 关闭文件流
f.close() # 读取出来列表后,关闭文件,继续在内存中操作,不影响后面读取文件,效率高
num = 0
for i in date:
num += 1
if num == 2:
print(i.strip(),'\t I love U')
else:
print(i.strip())
方案三: enumerate添加序列
# 打开文件流,以读的方式
f = open('hhh', 'r', encoding='utf-8')
# 文件操作,仅仅作输出显示用
for i, v in enumerate(f.readlines()):
if i == 1:
v = ''.join([v.strip(), ' I love U'])
print(i, v.strip())
# 关闭文件流
f.close()
方案四: 仅仅作输出显示用
# 打开文件流,以追加写的方式
f = open('hhh', 'r+', encoding='utf-8')
num = 0
for line in f:
num += 1
if num == 3:
line = ''.join([line.strip(), ' hello'])
print(line.strip())
# 关闭文件流
f.close()

文件的写入:

【没有文件,会创建文件,文件存在会清空原来的内容,重新写入】

# 打开文件流,以写的方式
f = open('hello', 'w', encoding='utf-8')
# 写内容进文件
file = f.write("hello world 2017")
# 关闭文件流
f.close()

文件的追加写入,默认在结尾直接追加,紧贴着原来

# 打开文件流,以追加的方式
f = open('hello', 'a', encoding='utf-8')
# 写内容进文件
f.write("\r黄山百战穿金甲,不破楼兰终不还\r") # 这里增加了换行\r黄山
f.write("夜阑卧听风吹雨,铁马冰河入梦来\r")
f.write("--2017-12-08".rjust(38, ' ')) # 增加了向右边增加空格的操作
# 关闭文件流
f.close()

文件的其他操作:

tell(): 查找光标, 英文字母读一个光标移动一次,中文读一个字符光标移动3个位置

tell读取英文:

# 打开文件流,以读的方式
f = open('hhh', 'r', encoding='utf-8')
# 文件操作,直接操作文件,Python会自动将for作为一个迭代器来输出,用一个选择一个来输出
print(f.tell())
print(f.read(3))
print(f.tell())
# 关闭文件流
f.close()

tell()读取:记录光标的位置

# 打开文件流,以读的方式
f = open('hhh', 'r', encoding='utf-8')
# 文件操作,直接操作文件,Python会自动将for作为一个迭代器来输出,用一个选择一个来输出
print(f.tell())
print(f.read(3))
print(f.tell())
# 关闭文件流
f.close()

文件的seek()操作:调整光标的位置,一般用于文件的断点传播,迅雷下载

# 打开文件流,以读的方式
f = open('hhh', 'r', encoding='utf-8')
# 文件操作,直接操作文件,Python会自动将for作为一个迭代器来输出,用一个选择一个来输出
print("调整前:", f.tell())
print(f.read(3))
print(f.tell())
f.seek(0)
print("调整后:", f.tell())
print(f.read(3))
print(f.tell())
# 关闭文件流
f.close()

文件的flush()操作:将缓存中的数据写入到硬盘

文件的flush()应用:打印进度条

import sys, time
for i in range(30):
# sys.stdout 相当于f对象
sys.stdout.write('.')
# 如果不添加flush(),则会等到30秒之后,一起打印出来30个dian
sys.stdout.flush()
time.sleep(1)

文件的truncate(): 文件的阶段,默认从头开始截取全部,相当于删除文件内容

适用于append模式,因为w模式默认会先truncate()

不常用

文件的fileno():返回一个整数,代表文件描述符,在内存中唯一的

文件的isatty ():判断文件是否是终端

文件选优操作

[推荐]文件的迭代输出:不再内存中操作文件,用一个从硬盘读取一行[默认输出一行],用完就结束

小文件,相比较readlines效率低一点,因为有一个转换的过程。大文件有优势,不占用内存

解释:readlines会将整个的文件读取到内存中,但是相对于10G等大文件,内存吃不消,所以建议文件读的时候,用for提供迭代器输出,用一行读取一行到内存,用完就释放内存。

文件的迭代输出

# 打开文件流,以读的方式
f = open('hhh', 'r', encoding='utf-8')
# 直接操作文件,Python会自动将f对象作为一个迭代器来输出,用一个选择一个来输出
for i in f:
print(i.strip())
# 关闭文件流
f.close()

文件操作之修改磁盘文件:

# 在第二行添加一句 Hello 2017
f_read = open('hhh', 'r', encoding='utf-8')
f_write = open('hhh_2', 'a+', encoding='utf-8')
num = 0
for i in f_read:
num += 1
if num == 2:
i = ''.join([i.strip(), '\t Hello 2017'])
f_write.write(i.strip()+'\n')
f_write.flush()
f_read.close()
f_write.close()

with语句

with语句为了避免打开文件后忘记关闭,可以通过管理上下文,当with代码块执行完毕时,内部会自动关闭并释放文件资源。【在Python 2.7 后,with又支持同时对多个文件的上下文进行管理】

with open('hhh', 'r', encoding='utf-8') as f1, open('hhh_2', 'r', encoding='utf-8') as f2:
print(f1.read())
print("----------------------------------")
print(f2.read())
# python会自动关闭释放内存

字典的文件读取:

dic = str({'name':'hhh', 'age':23})

with open('hhh', 'r', encoding='utf-8') as f:
# f.write(dic)
date = f.read()
print(eval(date)['age'])
print(eval(date)['name'])

三级菜单升级版[增加文件+增删改]

1. 展示省市区(数据在文件中)

2. 可以增加新的省份,文件会更新

【三级菜单参考】

Python实例---三级菜单的实现[low]

Python实例---三级菜单的实现[high]

Python学习---文件操作的学习1208的更多相关文章

  1. Python :open文件操作,配合read()使用!

    python:open/文件操作 open/文件操作f=open('/tmp/hello','w') #open(路径+文件名,读写模式) 如何打开文件 handle=open(file_name,a ...

  2. 孤荷凌寒自学python第三十五天python的文件操作之针对文件操作的os模块的相关内容

     孤荷凌寒自学python第三十五天python的文件操作之针对文件操作的os模块的相关内容 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 一.打开文件后,要务必记得关闭,所以一般的写法应当 ...

  3. 孤荷凌寒自学python第三十三天python的文件操作初识

     孤荷凌寒自学python第三十三天python的文件操作初识 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 今天开始自学python的普通 文件操作部分的内容. 一.python的文件打开 ...

  4. Python 常见文件操作的函数示例(转)

    转自:http://www.cnblogs.com/txw1958/archive/2012/03/08/2385540.html # -*-coding:utf8 -*- ''''' Python常 ...

  5. python中文件操作的六种模式及对文件某一行进行修改的方法

    一.python中文件操作的六种模式分为:r,w,a,r+,w+,a+ r叫做只读模式,只可以读取,不可以写入 w叫做写入模式,只可以写入,不可以读取 a叫做追加写入模式,只可以在末尾追加内容,不可以 ...

  6. python中文件操作的其他方法

    前面介绍过Python中文件操作的一般方法,包括打开,写入,关闭.本文中介绍下python中关于文件操作的其他比较常用的一些方法. 首先创建一个文件poems: p=open('poems','r', ...

  7. Python常见文件操作的函数示例

    # -*-coding:utf8 -*- ''''' Python常见文件操作示例 os.path 模块中的路径名访问函数 分隔 basename() 去掉目录路径, 返回文件名 dirname() ...

  8. python的文件操作及简单的用例

    一.python的文件操作介绍 1.文件操作函数介绍 open() 打开一个文件 语法:open(file, mode='r', buffering=-1, encoding=None, errors ...

  9. python基本文件操作

    python文件操作 python的文件操作相对于java复杂的IO流简单了好多,只要关心文件的读和写就行了 基本的文件操作 要注意的是,当不存在某路径的文件时,w,a模式会自动新建此文件夹,当读模式 ...

随机推荐

  1. Jmeter之测试报告

    当我们完成测试后,需要通过报告来查看测试结果 一.聚合报告 Label:每个JMeter的element的Name值.例如HTTP Request的Name #Samples:发出请求数量.例如:如第 ...

  2. 【分步详解】两个有序数组中的中位数和Top K问题

    (这也是一道leetcode的经典题目:<LeetCode>解题笔记:004. Median of Two Sorted Arrays[H] 问题介绍 这是个超级超级经典的分治算法!!这个 ...

  3. MapReduce原理——分而治之

    一.MapReduce简介 二.MapReduce并行处理的基本过程 三.MapReduce实际处理流程 四.一个job的运行流程 一.MapReduce简介 MapReduce是一种并行可扩展计算模 ...

  4. PHP将字符串写入txt文件

    function writelog($str) { $open=fopen("e:\log.txt","a" ); fwrite($open,$str); fc ...

  5. Win10双网卡不双待攻略

    声明:本文与个人的技术兴趣毫无关系,只是因为有迫不得已的实际需求,才不得不想办法.所谓"艰难困苦,玉汝于成",大概就是这个道理.(PS:标题我没有写错,不是双网卡双待,就是双网卡但 ...

  6. Java对zip格式压缩和解压缩

    Java对zip格式压缩和解压缩 通过使用java的相关类可以实现对文件或文件夹的压缩,以及对压缩文件的解压. 1.1 ZIP和GZIP的区别 gzip是一种文件压缩工具(或该压缩工具产生的压缩文件格 ...

  7. 二、hive shell常用命令

    在使用hive shell之前我们需要先安装hive,并启动hdfs 请参考:https://www.cnblogs.com/lay2017/p/9973298.html hive shell 我们先 ...

  8. sql = 和<>遵循的sql-92标准的设置SET ANSI_NULLS ON

    说明 SQL-92 标准要求在对空值进行等于 (=) 或不等于 (<>) 比较时取值为 FALSE. 当 SET ANSI_NULLS 为 ON 时,即使 column_name 中包含空 ...

  9. 字符串数组中含有json转换

    [{'a':'1','b':'2'},{'c':'3','d':'4'}]" 解决 import net.sf.json.JSONArray; import net.sf.json.JSON ...

  10. ROS:消息发布器和订阅器(c++)

    学习资料主要源自http://wiki.ros.org/ROS/Tutorials/WritingPublisherSubscriber%28c%2B%2B%29 $ roscd beginner_t ...