文件操作

文件的打开与关闭

  • 打开文件

    使用open(文件名,访问方式)函数,可以打开一个已存在的文件,或者创建一个新的文件。

    示例如下:
f = open('test.txt') # 访问方式可以省略,默认以r(只读)的形式
f = open('test.txt', 'w')
f = open('test.txt', 'w', encoding="utf-8")

encoding默认时使用与操作系统一样的编码方式,window为gbk,linux为utf-8。在window中有的ide编码为utf-8,则在操作文件时需要额外设置encoding="utf-8"

访问方式 说明
r 以只读方式打开文本文件。文件的指针将会放在文件的开头。这是默认模式。
w 打开一文本个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
a 打开一个文本文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。

若要操作二进制文件(图片、视频等非文本文件),则在后面加b即可,例如rb,wb,ab

若要想对文件又读又写,则在后面加+号,例如r+,w+,a+,rb+,wb+,ab+.

  • 关闭文件

    close() 方法用于关闭一个已打开的文件。

    示例如下:
f.close()

关闭后的文件不能再进行读写操作, 否则会触发 ValueError 错误。

文件的读写

  • 写数据

    使用write()可以完成向文件写入数据

    当文件以文本文件打开时,write(str)传入的参数为str(字符串类型)

    当文件以二进制文件打开时,write(bytes)传入的参数为bytes(二进制类型)
# 以文本文件打开
f = open('test.txt', 'w', encoding="utf-8")
f.write('hello world, i am here!')
f.close() # 以二进制文件打开
f = open('test.txt', 'wb')
f.write('hello world, i am here!'.encode("utf-8"))
f.close()
  • 读数据(read)

    使用read(num)可以从文件中读取数据,num表示要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就表示读取文件中所有的数据

    示例如下:
f = open('test.txt')

content = f.read(5)

print(content)

print("-"*30)

content = f.read()

print(content)

f.close()

"""
输出结果:
hello
------------------------------
world, i am here!
"""

注意:如果读取了多次数据,那么后面读取的数据是从上次读完后的位置开始的

  • 读数据(readline)

    readline() 方法用于从文件读取整行,包括 "\n" 字符。如果指定了一个非负数的参数,则返回指定大小的字节数,包括 "\n" 字符。

    文件test.txt中内容如下:

1:www.runoob.com

2:www.runoob.com

3:www.runoob.com

4:www.runoob.com

5:www.runoob.com

示例如下:

f = open('test.txt', 'r')

content = f.readline()

print(content)

print("-"*30)

content = f.readline()

print(content)

f.close()

"""
输出结果:
1:www.runoob.com ------------------------------
2:www.runoob.com
"""
  • 读数据(readlines)

    就像read没有参数时一样,readlines可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素。

    示例如下:
f = open('test.txt', 'r')

content = f.readlines()

print(content)

f.close()
"""
输出结果:
['1:www.runoob.com\n', '2:www.runoob.com\n', '3:www.runoob.com\n', '4:www.runoob.com\n', '5:www.runoob.com']
"""

文件的定位读写

  • 获取当前读写的位置

    在读写文件的过程中,如果想知道当前的位置,可以使用tell()来获取

    文件test.txt中内容如下:

1:www.runoob.com

2:www.runoob.com

3:www.runoob.com

4:www.runoob.com

5:www.runoob.com

f = open("test.txt", "r")
str = f.read(3)
print("读取的数据是 : ", str) # 查找当前位置
position = f.tell()
print("当前文件位置 : ", position) str = f.read(3)
print("读取的数据是 : ", str) # 查找当前位置
position = f.tell()
print("当前文件位置 : ", position) f.close()
"""
读取的数据是 : 1:w
当前文件位置 : 3
读取的数据是 : ww.
当前文件位置 : 6
"""

注意:文件位置从0开始记

  • 定位到某个位置

    如果在读写文件的过程中,需要从另外一个位置进行操作的话,可以使用seek()

    seek(offset,from)有2个参数

    • offset:偏移量
    • from: 方向
      • 0:表示文件开头
      • 1:表示当前位置
      • 2:表示文件末尾
f = open("test.txt", "r")
str = f.readline()
print("读取的数据是 : ", str) # 查找当前位置
position = f.tell()
print("当前文件位置 : ", position) # 重新设置位置
f.seek(0, 0) # 查找当前位置
position = f.tell()
print("当前文件位置 : ", position) str = f.readline()
print("读取的数据是 : ", str) f.close()
"""
输出结果:
读取的数据是 : 1:www.runoob.com 当前文件位置 : 18
当前文件位置 : 0
读取的数据是 : 1:www.runoob.com
"""

文件的重命名、删除

有时候需要对文件进行重命名、删除等操作时,要用到我们Python中的os模块,os 模块提供了非常丰富的方法用来处理文件和目录。

  • 文件重命名

    os模块中的rename()可以完成对文件的重命名操作。

    语法:rename(需要修改的文件名,新的文件名)
import os
# 将文件a重命名为文件b
os.rename("a.txt","b.txt")
  • 删除文件

    os模块中的remove()可以完成对文件的删除操作

    语法:remove(待删除的文件名)
import os
os.remove("a.txt")

文件夹操作

实际开发中,有时需要用程序的方式对文件夹进行一定的操作,比如创建、删除等就像对文件操作需要os模块一样,如果要操作文件夹,同样需要os模块。

  • 创建文件夹
import os
os.mkdir("文件夹")
  • 获取当前目录
import os
os.getcwd()
  • 改变默认目录
# 表示跳到上一级目录
os.chdir("../")
  • 获取指定路径的目录列表
import os
# 不传入参数时,返回当前的路径的列表
os.listdir(path)
  • 删除文件夹
import os
os.rmdir("文件夹")

浅谈python中文件和文件夹的相关操作的更多相关文章

  1. 浅谈Oracle中物理结构(数据文件等。。。)与逻辑结构(表空间等。。。。。)

    初始Oracle时很难理解其中的物理结构和逻辑结构,不明白内存中和硬盘中文件的区别和联系,我也是初学Oracle,这里就简单的谈谈我我看法. 首先,你需要明白的一点是:数据库的物理结构是由数据库的操作 ...

  2. 浅谈hadoop中mapreduce的文件分发

    近期在做数据分析的时候.须要在mapreduce中调用c语言写的接口.此时就须要把动态链接库so文件分发到hadoop的各个节点上,原来想自己来做这个分发,大概过程就是把so文件放在hdfs上面,然后 ...

  3. 浅谈python中得import xxx,from xxx import xxx, from xxx import *

    在python中import跟from import都是用来导入的,但是导入的机制不同 1.import xxx:导入模块,或者文件夹,对于调用模块或者文件夹中子模块的变量或者函数,需要使用" ...

  4. 浅谈python中的“ ==” 与“ is”

    在python中,== 与 is 之间既有区别,又有联系,本文将通过实际代码的演示,力争能够帮助读到这篇文章的朋友以最短的时间理清二者的关系,并深刻理解它们在内存中的实现机制.扯淡的话不多说,下面马上 ...

  5. 浅谈python中字典append 到list 后值的改变问题

    看一个例子 ? 1 2 3 4 d={'test':1} d_test=d d_test['test']=2 print d 如果你在命令行实践的话,会发现你改动的是d_test ,但是d 也跟着改变 ...

  6. 浅谈python中的闭包函数

    闭包函数初探 通常我们定义函数都是这样定义的 def foo(): pass 其实在函数式编程中,函数里面还可以嵌套函数,如下面这样 def foo(): print("hello worl ...

  7. 浅谈python中的“ ==” 与“ is”、还有cmp

    总之,比较内容相等使用 ‘==’ 1.is" 是用来比较 a 和 b 是不是指向同一个内存单元,而"=="是用来比较 a 和 b指向的内存单元中的值是不是相等 2.pyt ...

  8. 浅谈Python中函数式编程、面向对象编程以及古怪的PythonIC

    1.函数式编程作为结构化编程的一种,正在受到越来越多的重视.那么什么事函数式编程呢? 在维基百科中给出了详细的定义,函数式编程又称泛函数编程,是一种编程规范,它将函数运算视为数学上的函数计算.简单的来 ...

  9. 浅谈python中__str__和__repr__的区别

    很多时候我们在创建一个类的时候,在终端打印类或者查看的时候一般都不会得到一个太满意的结果 class T: def __init__(self): self.color="red" ...

随机推荐

  1. eclipse+MyEclipse+WebLogic开发简单的EJB

    转载自http://blog.sina.com.cn/s/blog_678530f60100hxaf.html 说是转载,其实这是我个人在几年前新浪博客上发表的文章. 帮导师搞了一周的EJB,总算初步 ...

  2. 20131221-Dom练习-第二十六天(未完)

    [1] //总结,写代码,一要动脑,理解用脑 //二要练,要动手,要有用身体记忆代码的觉悟,记忆用手 //三学编程最快的方法是,直接接触代码,用脑,用手接触代码 //面向对象的编码方式,对象还是对象, ...

  3. 第一届合天杯河北科技大学网络安全技术大赛 web6 writeup

  4. 【机器学习理论】换底公式--以e,2,10为底的对数关系转化

    我们在推导机器学习公式时,常常会用到各种各样的对数,但是奇怪的是--我们往往会忽略对数的底数是谁,不管是2,e,10等. 原因在于,lnx,log2x,log10x,之间是存在常数倍关系. 回顾学过的 ...

  5. 在Linux上安装JDK8-教程

    xl_echo编辑整理.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!! --- > 这里使用的服务 ...

  6. springboot-权限控制shiro(一)

    1. 场景描述 (1)权限控制是IT项目特别是企业项目,绕不开的重要模块,接下来结合springboot介绍下权限控制框架shiro. (2)springboot集成shiro的东西有点多,一篇博客完 ...

  7. storm学习路线指南

    关于对storm的介绍已经有很多了,我这里不做过多的介绍,我介绍一下我自己的学习路线,希望能帮助一些造轮子的同学走一些捷径,毕竟我也是站在前人总结整理的基础上学习了,如果有不足之处,还请大家不要喷我. ...

  8. Spark 源码分析系列

    如下,是 spark 源码分析系列的一些文章汇总,持续更新中...... Spark RPC spark 源码分析之五--Spark RPC剖析之创建NettyRpcEnv spark 源码分析之六- ...

  9. 章节十五、3-对象仓库、Page Factory实例应用

    一.如何创建对象仓库 package pageclasses; import org.openqa.selenium.WebDriver; import org.openqa.selenium.Web ...

  10. Scrapy框架安装失败解决办法

    安装报错信息 正常安装: pip3 install scrapy 出现报错信息如下: 两种解决办法 第一种方法 最根本得解决办法 需要我们安装  Microsoft Visual C++ 14.0  ...