浅谈python中文件和文件夹的相关操作
文件操作
文件的打开与关闭
- 打开文件
使用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中文件和文件夹的相关操作的更多相关文章
- 浅谈Oracle中物理结构(数据文件等。。。)与逻辑结构(表空间等。。。。。)
初始Oracle时很难理解其中的物理结构和逻辑结构,不明白内存中和硬盘中文件的区别和联系,我也是初学Oracle,这里就简单的谈谈我我看法. 首先,你需要明白的一点是:数据库的物理结构是由数据库的操作 ...
- 浅谈hadoop中mapreduce的文件分发
近期在做数据分析的时候.须要在mapreduce中调用c语言写的接口.此时就须要把动态链接库so文件分发到hadoop的各个节点上,原来想自己来做这个分发,大概过程就是把so文件放在hdfs上面,然后 ...
- 浅谈python中得import xxx,from xxx import xxx, from xxx import *
在python中import跟from import都是用来导入的,但是导入的机制不同 1.import xxx:导入模块,或者文件夹,对于调用模块或者文件夹中子模块的变量或者函数,需要使用" ...
- 浅谈python中的“ ==” 与“ is”
在python中,== 与 is 之间既有区别,又有联系,本文将通过实际代码的演示,力争能够帮助读到这篇文章的朋友以最短的时间理清二者的关系,并深刻理解它们在内存中的实现机制.扯淡的话不多说,下面马上 ...
- 浅谈python中字典append 到list 后值的改变问题
看一个例子 ? 1 2 3 4 d={'test':1} d_test=d d_test['test']=2 print d 如果你在命令行实践的话,会发现你改动的是d_test ,但是d 也跟着改变 ...
- 浅谈python中的闭包函数
闭包函数初探 通常我们定义函数都是这样定义的 def foo(): pass 其实在函数式编程中,函数里面还可以嵌套函数,如下面这样 def foo(): print("hello worl ...
- 浅谈python中的“ ==” 与“ is”、还有cmp
总之,比较内容相等使用 ‘==’ 1.is" 是用来比较 a 和 b 是不是指向同一个内存单元,而"=="是用来比较 a 和 b指向的内存单元中的值是不是相等 2.pyt ...
- 浅谈Python中函数式编程、面向对象编程以及古怪的PythonIC
1.函数式编程作为结构化编程的一种,正在受到越来越多的重视.那么什么事函数式编程呢? 在维基百科中给出了详细的定义,函数式编程又称泛函数编程,是一种编程规范,它将函数运算视为数学上的函数计算.简单的来 ...
- 浅谈python中__str__和__repr__的区别
很多时候我们在创建一个类的时候,在终端打印类或者查看的时候一般都不会得到一个太满意的结果 class T: def __init__(self): self.color="red" ...
随机推荐
- eclipse+MyEclipse+WebLogic开发简单的EJB
转载自http://blog.sina.com.cn/s/blog_678530f60100hxaf.html 说是转载,其实这是我个人在几年前新浪博客上发表的文章. 帮导师搞了一周的EJB,总算初步 ...
- 20131221-Dom练习-第二十六天(未完)
[1] //总结,写代码,一要动脑,理解用脑 //二要练,要动手,要有用身体记忆代码的觉悟,记忆用手 //三学编程最快的方法是,直接接触代码,用脑,用手接触代码 //面向对象的编码方式,对象还是对象, ...
- 第一届合天杯河北科技大学网络安全技术大赛 web6 writeup
- 【机器学习理论】换底公式--以e,2,10为底的对数关系转化
我们在推导机器学习公式时,常常会用到各种各样的对数,但是奇怪的是--我们往往会忽略对数的底数是谁,不管是2,e,10等. 原因在于,lnx,log2x,log10x,之间是存在常数倍关系. 回顾学过的 ...
- 在Linux上安装JDK8-教程
xl_echo编辑整理.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!! --- > 这里使用的服务 ...
- springboot-权限控制shiro(一)
1. 场景描述 (1)权限控制是IT项目特别是企业项目,绕不开的重要模块,接下来结合springboot介绍下权限控制框架shiro. (2)springboot集成shiro的东西有点多,一篇博客完 ...
- storm学习路线指南
关于对storm的介绍已经有很多了,我这里不做过多的介绍,我介绍一下我自己的学习路线,希望能帮助一些造轮子的同学走一些捷径,毕竟我也是站在前人总结整理的基础上学习了,如果有不足之处,还请大家不要喷我. ...
- Spark 源码分析系列
如下,是 spark 源码分析系列的一些文章汇总,持续更新中...... Spark RPC spark 源码分析之五--Spark RPC剖析之创建NettyRpcEnv spark 源码分析之六- ...
- 章节十五、3-对象仓库、Page Factory实例应用
一.如何创建对象仓库 package pageclasses; import org.openqa.selenium.WebDriver; import org.openqa.selenium.Web ...
- Scrapy框架安装失败解决办法
安装报错信息 正常安装: pip3 install scrapy 出现报错信息如下: 两种解决办法 第一种方法 最根本得解决办法 需要我们安装 Microsoft Visual C++ 14.0 ...