6.2Python文件的操作(二)
目录
前言
该篇是相继上一篇6.1Python文件操作(一)之后的进阶文章。
(一)文件的定位
(1)说明
f.tell() 返回当前文件指针所在的位置。
f.seek(偏移量, 参考点) 根据参考点来偏移 偏移量个单位。
参考的:可以是0, 1, 2
0: 开头处, 参考点是正的
1:中间位置,参考点可正可负
2:结尾处:参考点是负的
注:文本文件的参考点只能是0,二进制文件三者皆可。
(2)源代码
# 打开
f = open("a.txt", "rb")
# 指针的位置
r1 = f.tell()
print("前指针的位置:", r1)
# 偏移指针,参考点: 文本文件只能是0,二进制文件可以是:1, 2
f.seek(-2, 2)
r1 = f.tell()
print("后指针的位置:", r1)
# 读
content = f.read()
print("内容是:", content)
r1 = f.tell()
print("读完指针的位置:", r1)
# 关闭
f.close()
(3)输出效果
a.txt的内容是:12345678

(二)文件的读操作
1.read()方法
(1)说明
f.readable()用于判断该文件是否可读
f.read(字节数) ,默认情况下字节 数是文件的长度。
(2)源代码
# 打开文件
f = open("b.txt", "r")
# 判断是否可读
print(f.readable())
if f.readable():
# 操作, n 要读的文件长度
content = f.read(5)
print(content)
# 关闭文件
f.close()
(3)输出效果
b.txt 的内容是:123456789

2.readline()方法
(1)说明
readline()方法是逐行的读写,每一次只读一行。
(2)源代码
# 打开文件
f = open("c.txt", "r")
# 操作, n 要读的文件长度
content = f.readline()
print(content, end='')
content = f.readline()
print(content, end='')
content = f.readline()
print(content, end='')
# 关闭文件
f.close()
(3)输出效果
c.txt的内容是:
12
34abcdefgh
56
78

3.readlines()方法
(1)说明
readlines()方法是以行为单位来读,返回每一行为一个元素的列表 。
(2)源代码
# 打开文件
f = open("c.txt", "r")
# 操作, n 要读的文件长度
content = f.readlines()
print(content)
# 关闭文件
f.close()
(3)输出效果
c.txt的内容是:
12
34abcdefgh
56
78

4.文件的遍历读法
(1)说明
打开的文件 f 本身就是一个迭代器,可以用for循环来遍历输出。与resdlines()类似,用行为单位来处理。
(2)源代码
# 打开文件
f = open("c.txt", "r")
# f是一个迭代器与readlines()效果一样
for i in f:
print(i, end='')
# 关闭文件
f.close()
(3)输出效果
c.txt的内容是:
12
34abcdefgh
56
78

(三)文件的写操作
1.write()方法
(1)说明
f.writable()用于判断该文件是否可选。
f.write()方法返回的是本次写入的字节数。
encoding="utf-8" 参数是指明写入的编码格式。
(2)源代码
# 打开文件
f = open("d.txt", "a", encoding="utf-8")
# 判断是否可写
if f.writable():
# 写入文件
result = f.write("123456")
print("写入的字节数是:", result)
# 关闭文件
f.close()
(3)输出效果

2.writelines()方法
(1)说明
f. writelines()方法是以列表的每一个元素,写入到文件的每一行,列表的元素必须是字符串类型。
注:每一个列表的元素后面需要添加 "\n" 才换行,默认是不换行。
(2)源代码
# 打开文件
f = open("e.txt", "w", encoding="utf-8")
# 写入文件
f_list = ["14\n", "28\n", "abc\n", "哈哈"]
f.writelines(f_list)
# 关闭文件
f.close()
(3)输出效果

(四)文件的关闭
(1)说明
f.close()是关闭文件,内部是把缓存区的数据,写到内存,才实现真正的保存操作。
同时也释放系统资源。
f.flush() 是立即把缓存区的数据写入到内存里区,实现及时的保存。
(2)源代码
# 打开文件
f = open("f.txt", "w")
# 操作文件
f.write("123456")
# 及时保存数据
f.flush()
# 关闭文件
f.close()
(3)输出效果

作者:Mark
日期:2019/02/08 周五
6.2Python文件的操作(二)的更多相关文章
- 6.3Pytyhon文件的操作(三)
目录 目录 前言 (一)文件的创建 (二)文件的删除 (三)文件的重命名 (四)文件的查看 (五)文件的复制 ==1.小文件的复制== ==2.大文件的复制== (六)文件的实战案例 ==1.文件的分 ...
- iOS 关于文件的操作
最近做东西,遇到了使用文件方面的问题,花了点时间把文件研究了一下! 一 关于文件路径的生成 我用的方法是: -(NSString*)dataFilePath { NSArray * paths = ...
- 《转》Python学习(15)-对文件的操作(二)
转自 http://www.cnblogs.com/BeginMan/p/3169020.html 一.文件系统 从系统角度来看,文件系统是对文件存储器空间进行组织和分配,负责文件存储并对存入的文件进 ...
- 【Python全栈笔记】05 [模块二] 19 Oct 文件的操作
文件操作 一般步骤1. 文件打开 2. 文件操作 3. 文件关闭 1. 打开文件 使用open(文件名(绝对路径), 打开模式, 编码) 文件打开的模式有: r: 只读模式(默认) w: 只写模式 ...
- python中常用的文件和目录操作(二)
一. os模块概述 python os模块提供了非常丰富的方法用来处理文件和目录 二. 导入os模块: import os 三. 常用方法 1. os.name 输出字符串表示正在使用的平台,如果是w ...
- Gradle系列之二 Groovy对文件的操作
Groovy对文件的操作 对文件的遍历 假设文件的原始内容为: hello,world 这里是北京 andorid and ios are good system 第一种方法:使用 eachLine( ...
- find命令进阶(二):对找到的文件执行操作exec
以下面的命令为例: find ~ -type f -name 'foo*' -exec ls -l '{}' ';' 分面两部分,第一部分: find ~ -type f -name 'foo*' 即 ...
- c语言文件读写操作总结
C语言文件读写操作总结 C语言文件操作 一.标准文件的读写 1.文件的打开 fopen() 文件的打开操作表示将给用户指定的文件在内存分配一个FILE结构区,并将该结构的指针返回给用户程序,以后用户程 ...
- python对文件的操作
一.python中对文件.文件夹操作时经常用到的os模块和shutil模块常用方法. 1.得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd() 2.返回指定目录下的所有文件 ...
随机推荐
- 从零开始学 Web 之 DOM(三)innerText与innerHTML、自定义属性
大家好,这里是「 Daotin的梦呓 」从零开始学 Web 系列教程.此文首发于「 Daotin的梦呓 」公众号,欢迎大家订阅关注.在这里我会从 Web 前端零基础开始,一步步学习 Web 相关的知识 ...
- bigdata-01-应用
1, 基本概念 在互联网技术发展到现今阶段,大量日常.工作等事务产生的数据都已经信息化,人类产生的数据量相比以前有了爆炸式的增长,以前的传统的数据处理技术已经无法胜任,需求催生技术,一套用来处理海量数 ...
- Java并发编程笔记之Timer源码分析
timer在JDK里面,是很早的一个API了.具有延时的,并具有周期性的任务,在newScheduledThreadPool出来之前我们一般会用Timer和TimerTask来做,但是Timer存在一 ...
- Angular2入门:TypeScript的函数 - 剩余参数和箭头函数
- 【NET CORE微服务一条龙应用】第一章 网关使用与配置
简介 微服务的系统应用中,网关系统使用的是ocelot,ocelot目前已经比较成熟了 ocelot就不做介绍了,等整体介绍完后再进行各类扩展介绍,ocelot源码地址:https://github. ...
- Redis基础认识及常用命令使用(一)--转载
Redis简介 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合)和zset(有序集 ...
- Memcached部署和用法
一.Memcached简介 Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网 ...
- 【Java并发编程】6、volatile关键字解析&内存模型&并发编程中三概念
volatile这个关键字可能很多朋友都听说过,或许也都用过.在Java 5之前,它是一个备受争议的关键字,因为在程序中使用它往往会导致出人意料的结果.在Java 5之后,volatile关键字才得以 ...
- 【高并发解决方案】7、一致性hash解读
一致性哈希算法在1997年由麻省理工学院提出的一种分布式哈希(DHT)实现算法,设计目标是为了解决因特网中的热点(Hot spot)问题,初衷和CARP十分类似.一致性哈希修正了CARP使用的简 ...
- 【代码笔记】Web-HTML-布局
一, 效果图. 二,代码. <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...