目录

前言

该篇是相继上一篇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文件的操作(二)的更多相关文章

  1. 6.3Pytyhon文件的操作(三)

    目录 目录 前言 (一)文件的创建 (二)文件的删除 (三)文件的重命名 (四)文件的查看 (五)文件的复制 ==1.小文件的复制== ==2.大文件的复制== (六)文件的实战案例 ==1.文件的分 ...

  2. iOS 关于文件的操作

    最近做东西,遇到了使用文件方面的问题,花了点时间把文件研究了一下! 一  关于文件路径的生成 我用的方法是: -(NSString*)dataFilePath { NSArray * paths = ...

  3. 《转》Python学习(15)-对文件的操作(二)

    转自 http://www.cnblogs.com/BeginMan/p/3169020.html 一.文件系统 从系统角度来看,文件系统是对文件存储器空间进行组织和分配,负责文件存储并对存入的文件进 ...

  4. 【Python全栈笔记】05 [模块二] 19 Oct 文件的操作

    文件操作 一般步骤1. 文件打开 2. 文件操作 3. 文件关闭 1. 打开文件 使用open(文件名(绝对路径), 打开模式, 编码) 文件打开的模式有: r:  只读模式(默认) w: 只写模式 ...

  5. python中常用的文件和目录操作(二)

    一. os模块概述 python os模块提供了非常丰富的方法用来处理文件和目录 二. 导入os模块: import os 三. 常用方法 1. os.name 输出字符串表示正在使用的平台,如果是w ...

  6. Gradle系列之二 Groovy对文件的操作

    Groovy对文件的操作 对文件的遍历 假设文件的原始内容为: hello,world 这里是北京 andorid and ios are good system 第一种方法:使用 eachLine( ...

  7. find命令进阶(二):对找到的文件执行操作exec

    以下面的命令为例: find ~ -type f -name 'foo*' -exec ls -l '{}' ';' 分面两部分,第一部分: find ~ -type f -name 'foo*' 即 ...

  8. c语言文件读写操作总结

    C语言文件读写操作总结 C语言文件操作 一.标准文件的读写 1.文件的打开 fopen() 文件的打开操作表示将给用户指定的文件在内存分配一个FILE结构区,并将该结构的指针返回给用户程序,以后用户程 ...

  9. python对文件的操作

    一.python中对文件.文件夹操作时经常用到的os模块和shutil模块常用方法. 1.得到当前工作目录,即当前Python脚本工作的目录路径: os.getcwd() 2.返回指定目录下的所有文件 ...

随机推荐

  1. 读vue-0.6-observer.js源码

    实现监听数组方法 var ArrayProxy = Object.create(Array.prototype), methods = ['push','pop','shift','unshift', ...

  2. rhel 配置centos源

    1.删除自带的yum包,清除/etc/yum.repos.d下面的文件 rpm -qa|grep yum|xargs rpm -e --nodeps(不检查依赖,直接删除rpm包) 2.安装cento ...

  3. Java 8 新特性-菜鸟教程 (7) -Java 8 Nashorn JavaScript

    Java 8 Nashorn JavaScript Nashorn 一个 javascript 引擎. 从JDK 1.8开始,Nashorn取代Rhino(JDK 1.6, JDK1.7)成为Java ...

  4. [译]ABP vNext微服务演示,项目状态和路线图

    译注: ABP的主要负责人hikalkan最近又发布了一篇博客, 说明了ABP vNext的微服务演示,项目状态和路线图.其中特意对ABP的中文社区进行了感谢! 本文翻译自该博客文章(https:// ...

  5. Log4j 随笔

    对于一个Java开发者而言,Log4j是我们的好朋友了.话说到这里,需要自我检讨一下,这么久以来,凡是用到Log4j的地方,相关的配置文件都是直接拷贝过去,从来都没仔细看过.But thanks Go ...

  6. 配置IIS的负载均衡

    在大型Web应用系统中,由于请求的数据量过大以及并发的因素,导致Web系统会出现宕机的现象,解决这一类问题的方法我个人觉得主要在以下几个方面: 1.IIS 负载均衡. 2.数据库 负载均衡. 3.系统 ...

  7. Spark新手入门——3.Spark集群(standalone模式)安装

    主要包括以下三部分,本文为第三部分: 一. Scala环境准备 查看二. Hadoop集群(伪分布模式)安装 查看三. Spark集群(standalone模式)安装 Spark集群(standalo ...

  8. MyBatis——MyEclipse中使用mybatis-generator

    mybatis-generator可以根据数据库的表来生成POJO类.mapper.xml和DAO接口,用这个插件会大大地提高开发的效率.网上虽然有一些使用这个插件的教程,但我单个试了并不能成功,会出 ...

  9. CentOS7 config aliyun yum repository

    https://www.cnblogs.com/lpbottle/p/7875400.html 1. 备份原来的yum源 mv /etc/yum.repos.d/CentOS-Base.repo /e ...

  10. Harbor 搜索镜像及查看 tag

    在我们搭建完 Harbor 后: https://www.cnblogs.com/klvchen/p/9482153.html 如果想要通过 API 获取 Harbor 上面的镜像及 tag 可以使用 ...