https://www.jianshu.com/p/eab35af27e1c

1.打开文件操作

  方法一:

f = open('/mypy/test.txt')
print f
# 输出:<open file 'test.txt',mode 'r' at...>
# 注:如果打开文件的时候不指定模式,默认以`r`模式打开,表示只读

 方法二:

f = file('test.txt')
print f
# 输出:同上

可见,file()函数和open()函数有着相似的功能。

读取文件内容

f = open('test.txt')
print f.read()

输出:

www.test.com
hello

关闭文件

f.close()

向文件中写入内容

f = open('test.txt')
f.write('new')
# 报错:IOError: File not open for writing

这样写入内容报错的原因是,以只读方式打开的文件不允许写入内容,而要这样:

f = open('test.txt','w+')
f.write('new')

执行上面代码,发现这次没有报错,可是去看test.txt文件的内容,并没有新写入的new,这是为何呢?是因为还没有执行f.close()操作,所以文件还并没有被保存,再执行一下f.close()操作,现在再去看文件内容,发现为:

new.test.com
hello

虽然把最新内容new写入了文件,但是却是覆盖了文件的前三个字符,这不是我们想要的,我们想把内容写到文件末尾,这里牵扯到文件指针的问题(后面讲),要达到这个目的,需要这样做:

f = open('test.txt')
f.read()
f.write('new')
f.close()

再次执行上述操作,发现文件test.txt的末尾成功新增一行new

用with语句操作文件

打开文件,推荐使用上下文管理器with语句,它可以自动管理文件的打开和关闭,用了它以后就不需手工关闭文件,并且支持一次打开多个文件,非常方便,标准用法如下:

with open('test1.txt','w+') as f1, open('test2.txt','w+') as f2:
f1.write('123')
f2.write('456')

文件对象常用函数

open

打开一个文件,其实file()函数也可以打开一个文件,但是推荐首先open()函数。open()函数返回一个file对象,是一个可迭代对象,例如依次读取并输出一个文件的每一行的内容:

f = open('file.txt')
for line in f:
print line

read

若不传入参数,表示从当前文件指针所在位置读到文件末尾;若传入一个表示size的参数,表示从当前文件指针所在位置往后读size个字节,例如:

f = open('file.txt')
# 从开头往后读3个字节
f.read(3)
# 从第3个字节处往后读5个字节
f.read(5)
# 从第8个字节处读到文件末尾
f.read()

close

关闭文件:

f = open('file.txt')
f.close()

readline

每次读文件的一行,如果不传入任何参数,表示每次读一行的所有字符;如果传入一个表示字节的size参数,表示读一行的前size个字节,如果上一次本行没有读完,则下一次会接着读,直到行尾。

readlines

返回一个列表,是包含一个文件的每一行内容的字符串列表。

next

返回文件的下一行。

write

往文件中从当前文件指针处写入内容。

writelines

传入一个字符串列表参数,将该字符串列表写入文件。

flush

修改文件内容后,提交更新。

seek(偏移量, 选项)

  • 选项 = 0:把文件指针从文件头部向后(不能向前)移动偏移量那么多的字节。
  • 选项 = 1:把文件指针从当前位置向后(不能向前)移动偏移量那么多的字节。
  • 选项 = 2:把文件指针从文件尾部向前移动偏移量那么多的字节。

一个原则:移动不能越界,否则会出错。

一个例子:将文件指针移到文件开头:

f = open('file.txt')
f.seek(0,0)

os模块常用函数

os模块有很多实用的文件、目录和路径操作相关的函数,下面介绍几个最经常用到的。

os.system()

基于当前目录执行shell命令,并返回命令的执行结果。函数原型:

Docstring:
system(command) -> exit_status Execute the command (a string) in a subshell.
Type: builtin_function_or_method

os.mkdir()

创建目录,函数原型:

mkdir(path [, mode=0777])

Create a directory.
Type: builtin_function_or_method

举例:

# 在当前目录下创建名为dir1的目录
os.mkdir('dir1')
# 使用该方法创建嵌套多层目录会报错
os.mkdir('a/b/c')
# 列出path顶层目录下的文件和文件夹(随机顺序)
os.listdir(path)

os.makedirs()

创建多级目录,函数原型:

Signature: os.makedirs(name, mode=511)
Docstring:
makedirs(path [, mode=0777]) Super-mkdir; create a leaf directory and all intermediate ones.
Works like mkdir, except that any intermediate path segment (not
just the rightmost) will be created if it does not exist. This is
recursive.
File: e:\code\env\.env\lib\os.py
Type: function

os.rmdir()

删除目录(需要是空目录),函数原型:

Docstring:
rmdir(path) Remove a directory.
Type: builtin_function_or_method

示例:

os.mkdir('dir1')
# 删除目录dir1
os.rmdir('dir1') os.makedirs('a/b/c')
# c目录被删掉(若path为多级目录,则只有最低一级的目录被删掉)
os.rmdir('a/b/c') # 删除失败,提示:OSError: Directory not empty:a,目录非空,无法删除
os.rmdir('a')

os.removedirs()

删除空的多级目录(目录中没有文件),函数原型:

Signature: os.removedirs(name)
Docstring:
removedirs(path) Super-rmdir; remove a leaf directory and all empty intermediate
ones. Works like rmdir except that, if the leaf directory is
successfully removed, directories corresponding to rightmost path
segments will be pruned away until either the whole path is
consumed or an error occurs. Errors during this latter phase are
ignored -- they generally mean that a directory was not empty.
File: e:\code\env\.env\lib\os.py
Type: function

示例:

os.makedirs('a/b/c')
# 将'a/b/c'三级目录同时删掉
os.removedirs('a/b/c') os.makedirs('a/b/c')
# 然后在'a/b'目录下创建一个名为'file.txt'的文件
# 发现这时只有c目录能被删掉,a、b目录及file.txt文件都还在
os.removedirs('a/b/c') # 报错:OSError: Directory not empty:'a/b'
os.removedirs('a/b')

os.getcwd()

获取当前的工作目录,函数原型:

Docstring:
getcwd() -> path Return a string representing the current working directory.
Type: builtin_function_or_method

os.chdir()

修改当前的工作目录,影响os.getcwd()函数的返回值,函数原型:

Docstring:
chdir(path) Change the current working directory to the specified path.
Type: builtin_function_or_method

os.path的几个实用函数

  • os.path.isabs()
    判断某个路径是否是一个绝对路径。

  • os.path.isdir()
    判断某个路径是否是一个存在的路径。

  • os.path.isfile()
    判断某个路径是否是一个文件。

  • os.path.islink()
    判断某个路径是否是一个超链接。但注意到函数说明中有这么一句话:

Signature: os.path.islink(path)
Docstring:
Test for symbolic link.
On WindowsNT/95 and OS/2 always returns false

WindowsNT/95OS/2系统,os.path.islink()函数总是返回false

  • os.path.ismount()
    判断某个路径是否是一个挂载点:
Test whether a path is a mount point (defined as root of drive)
  • os.path.abspath()
    以当前工作目录为前缀,把一个相对路径转为绝对路径。

  • os.path.basename()
    获取一个路径代表的文件名(包括后缀名)。

  • os.path.exists()
    判断某个路径是否存在(可以为目录路径也可以为文件路径)。

  • os.path.join(path1,*path)
    拼接2个或多个路径,若其中一个为绝对路径,那它之前的路径都会被忽略。

os.walk(top, topdown = True, onerror = None)

遍历根目录top,递归地返回一个三元组:

(root, dirs, files)

其中,root为根目录路径,dirsroot路径下的目录列表,filesroot路径下的文件列表。

topdown参数表示是否从顶层目录开始遍历,onerror是发生错误时候的回调函数

作者:m2fox
链接:https://www.jianshu.com/p/eab35af27e1c
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

Python文件读写基本操作的更多相关文章

  1. python文件读写及形式转化和CGI的简单应用

    一丶python文件读写学习笔记 open() 将会返回一个 file 对象,基本语法格式如下: open(filename, mode) filename:包含了你要访问的文件名称的字符串值. mo ...

  2. python 文件读写操作(24)

    以前的代码都是直接将数据输出到控制台,实际上我们也可以通过读/写文件的方式读取/输出到磁盘文件中,文件读写简称I/O操作.文件I/O操作一共分为四部分:打开(open)/读取(read)/写入(wri ...

  3. Python 文件读写,条件循环(三次登录锁定账号实例)

    通过文件读写,条件循环相关语法,实现三次登录失败则锁定该账号的功能 需求一 """需求描述: 1.输入正确账号,密码,退出程序 2.登录失败,重新输入账号密码 3.同一账 ...

  4. 【学习】python文件读写,用with open as的好处,非常好【转载】

    原文链接:http://www.cnblogs.com/ymjyqsx/p/6554817.html 备注:博主还有很多值得学习的笔记,遇到问题可以拜读,非常感谢博主的总结 读写文件是最常见的IO操作 ...

  5. python文件读写,以后就用with open语句

    读写文件是最常见的IO操作.Python内置了读写文件的函数,用法和C是兼容的. 读写文件前,我们先必须了解一下,在磁盘上读写文件的功能都是由操作系统提供的,现代操作系统不允许普通的程序直接操作磁盘, ...

  6. Python文件读写(open(),close(),with open() as f...)

    Python内置了读写文件的函数,用法和C是兼容的.本节介绍内容大致有:文件的打开/关闭.文件对象.文件的读写等. 本章节仅示例介绍 TXT 类型文档的读写,也就是最基础的文件读写,也需要注意编码问题 ...

  7. python 文件读写方式

    一.普通文件读写方式 1.读取文件信息: with open('/path/to/file', 'r') as f: content = f.read() 2.写入文件中: with open('/U ...

  8. Python文件读写、StringIO和BytesIO

    1 IO的含义 在计算机中,IO是Input/Output的简写,也就是输入和输出. 由于程序和运行时数据是在内存中驻留,由CPU这个超快的计算核心来执行,涉及到数据交换的地方,通常是磁盘.网络等,就 ...

  9. python文件读写小结

    读文件 打开一个文件用open()方法(open()返回一个文件对象,它是可迭代的): >>> f = open('test.txt', 'r') r表示是文本文件,rb是二进制文件 ...

随机推荐

  1. Gcc如何知道文件类型。

    Linux系统不区分扩展名,但是GCC编译器通过扩展名区分. GCC是根据扩展名来编译源文件的.

  2. 分布式FastDfs+nginx缓存高可用集群构建

    介绍: FastDFS:开源的高性能分布式文件系统:主要功能包括:文件存储,文件同步和文件访问,以及高容量和负载平衡 FastDFS:角色:跟踪服务器(Tracker Server).存储服务器(St ...

  3. Codeforces 920 反图联通块 线段树质因数暴力

    A #include <bits/stdc++.h> #define PI acos(-1.0) #define mem(a,b) memset((a),b,sizeof(a)) #def ...

  4. MySQL--全文索引作用、原理及使用注意

    作用 MySQL索引可以分为:主键索引.普通索引.唯一索引.全文索引.其中,全文索引应该是是比较特殊的,它只有少数的几个存储引擎支持,且只有类型为char.vchar.text的列能建立全文索引.以前 ...

  5. ubuntu16.04 配置tomcat开机启动

    使用脚本方式设置开机启动 1.将tomcat目录下/bin中的catalina.sh拷贝到/etc/init.d下: cp /usr/local/java/apache-tomcat-/bin/cat ...

  6. 【leetcode】299. Bulls and Cows

    题目如下: 解题思路:本题难度不太大,对时间复杂度也没有很高的要求.我的做法是用一个字典来保存每个字符出现的次数,用正数1记录标记secret中出现的字符,用负数1记录guess中出现的字符,这样每出 ...

  7. 阿里云产品家族再添新丁:视觉AI、CPFS一体机助力企业全面上云

    近日举行的2019阿里云广东峰会上,阿里云宣布推出面向混合云场景的CPFS一体机和视觉AI一体机,两款新品具备超高性能.开箱即用等特性,极大降低企业上云的周期和门槛. 加上此前推出的POLARDB数据 ...

  8. IDEA将新建项目上传至GitLab

    1.首先,需要你自己登录GitLab,并新建一个项目的链接,如下图所示: (此图为图三,该链接下面操作中将会用到!) 2.在idea上新建一个项目,完成之后,需要创建一个git仓库: 3.然后可以根据 ...

  9. Distinctive Image Features from Scale-Invariant Keypoints(SIFT) 基于尺度不变关键点的特征描述子——2004年

    Abstract摘要本文提出了一种从图像中提取特征不变性的方法,该方法可用于在对象或场景的不同视图之间进行可靠的匹配(适用场景和任务).这些特征对图像的尺度和旋转不变性,并且在很大范围的仿射失真.3d ...

  10. 6.12友谊赛T4城市交通费题解

    与普通的最短路径不同的是,题目中新引入了一个计入总体的费用——城市建设费.由于城市建设费由整体的某最大值决定,导致解没有最优子结构的性质,给思维带来难度. 既然最棘手的是城市建设费,我们就对它分类讨论 ...