文件操作,内置函数open()
先看看官方说明:

The default mode is 'r' (open for reading text, synonym of 'rt'). For binary read-write access, the mode 'w+b' opens and truncates the file to 0 bytes. 'r+b' opens the file without truncation.
As mentioned in the Overview, Python distinguishes between binary and text I/O. Files opened in binary mode (including 'b' in the mode argument) return contents as bytes objects without any decoding.
In text mode (the default, or when 't' is included in the mode argument), the contents of the file are returned as str, the bytes having been first decoded using a platform-dependent encoding or using the specified encoding if given.
r、w、a 为打开文件的基本模式,分别对应只读、只写、追加模式。
b、t、+ 与以上的文件打开模式组合使用,分别对应二进制模式,文本模式,读写模式。
整理一下:
———————————————————————————————————————————————————————————————————————————————————————
mode | 描述
———————————————————————————————————————————————————————————————————————————————————————
r | 以只读方式打开文件(默认),如果文件不存在,则抛出FileNotFoundError异常
———————————————————————————————————————————————————————————————————————————————————————
w | 以只写方式打开文件。指针在开头,文件不存在时创建,文件存在时,则清空再写入新内容。
———————————————————————————————————————————————————————————————————————————————————————
a | 以追加只写方式打开文件,指针移到文件末尾。文件不存在时创建。
———————————————————————————————————————————————————————————————————————————————————————
x | 以追加方式打开文件,文件不存在时创建,文件存在时抛出FileExistsError异常。
———————————————————————————————————————————————————————————————————————————————————————
r+ | 读写,指针在开头,可以写到文件任何位置
———————————————————————————————————————————————————————————————————————————————————————
w+ | 读写,清空文件内容
———————————————————————————————————————————————————————————————————————————————————————
a+ | 读写,追加,只能写在文件末尾
———————————————————————————————————————————————————————————————————————————————————————
打开文件
f = open('path','mode')
将内存数据写入文件
f.flush()
关闭文件
f.close()
创建一个文件
# vim users.txt
keith1:18:110
keith2:19:111
keith3:20:112
keith4:21:113
查看帮助文档
>>> f=open('users.txt')
>>> type(f)
<class '_io.TextIOWrapper'>
>>> help(open)
>>> help(f)
>>> dir(f)
['_CHUNK_SIZE', '__class__', '__del__', '__delattr__', '__dict__', '__dir__', '__doc__', '__enter__', '__eq__', '__exit__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__lt__', '__ne__', '__new__', '__next__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '_checkClosed', '_checkReadable', '_checkSeekable', '_checkWritable', '_finalizing', 'buffer', 'close', 'closed', 'detach', 'encoding', 'errors', 'fileno', 'flush', 'isatty', 'line_buffering', 'mode', 'name', 'newlines', 'read', 'readable', 'readline', 'readlines', 'seek', 'seekable', 'tell', 'truncate', 'writable', 'write', 'writelines']
在对文件进行操作后,一定要牢记一件事情:file.close()。
如果不关闭,它还驻留在内存中,后面又没有对它的操作,既浪费内存空间,也增加了文件的安全风险。
有另一种方法能够不用手动close()文件,那就是使用with的方式打开文件。
>>> with open('users.txt') as f:
... print(f.read())
...
keith1:18:110
keith2:19:111
keith3:20:112
keith4:21:113
读文件
f.read(size) 读取文件size个字节内容,返回字符串。如果不指定size,则读取全部内容。
f.readline(size) 读取文件一行size个字节,返回字符串。如果不指定size,则显示一整行。
f.readlines(hint) 读取文件所有行,返回列表。如果hint小于一行的字符数则读取一行,如果hint大于一行小于两行字符数则读取两行,以此类推。
>>> help(f.read)
Help on built-in function read:
read(size=-1, /) method of _io.TextIOWrapper instance
Read at most n characters from stream.
Read from underlying buffer until we have n characters or we hit EOF.
If n is negative or omitted, read until EOF.
>>> help(f.readline)
Help on built-in function readline:
readline(size=-1, /) method of _io.TextIOWrapper instance
Read until newline or EOF.
Returns an empty string if EOF is hit immediately.
>>> help(f.readlines)
Help on built-in function readlines:
readlines(hint=-1, /) method of _io.TextIOWrapper instance
Return a list of lines from the stream.
hint can be specified to control the number of lines read: no more
lines will be read if the total size (in bytes/characters) of all
lines so far exceeds hint.
>>> f.read()
'keith1:18:110\nkeith2:19:111\nkeith3:20:112\nkeith4:21:113'
>>> f.readline()
'keith1:18:110\n'
>>> f.readlines()
['keith1:18:110\n', 'keith2:19:111\n', 'keith3:20:112\n', 'keith4:21:113']
在python中,'\n'表示换行,这也是unix系统中的规范。但是在windows系统中,用'\r\n'表示换行。不过还好,python在处理的时候,会自动将'\r\n'转换为'\n'。
遍历文件
>>> f=open('users.txt')
>>> for line in f:
... print(line, end='')
...
keith1:18:110
keith2:19:111
keith3:20:112
keith4:21:113
for循环是一行一行地读取文件内容,每次扫描一行,遇到结束符号\n表示本行结束。
文件指针
指针就是文件操作的位置。
获取指针当前位置
>>> help(f.tell)
Help on built-in function tell:
tell() method of _io.TextIOWrapper instance
Return current stream position.
移动指针
>>> help(f.seek)
Help on built-in function seek:
seek(cookie, whence=0, /) method of _io.TextIOWrapper instance
Change stream position.
Change the stream position to the given byte offset.
The offset is interpreted relative to the position indicated by whence.
Values for whence are:
* 0 -- start of stream (the default); offset should be zero or positive 默认为起始位置,偏移量为0或者正数。
* 1 -- current stream position; offset may be negative 当前位置,偏移量可以是负数。
* 2 -- end of stream; offset is usually negative 结束位置,偏移量通常是负数。
Return the new absolute position.
cookie表示相对whence的偏移量。
whence表示从何处开始。
>>> f=open('users.txt')
>>> f.tell()
0
>>> f.read(2)
'ke'
>>> f.tell()
2
>>> f.read(3)
'ith'
>>> f.tell()
5
>>> f.seek(0)
0
>>> f.tell()
0
需要注意的是,seek移动指针之前默认先会调用flush。
参考:
https://docs.python.org/3/library/functions.html#open
https://docs.python.org/3/library/io.html#io.TextIOBase.seek
http://www.runoob.com/python/file-seek.html
https://docs.python.org/3/library/io.html#io.IOBase.writelines
文件操作,内置函数open()的更多相关文章
- [转]python file文件操作--内置对象open
python file文件操作--内置对象open 说明: 1. 函数功能打开一个文件,返回一个文件读写对象,然后可以对文件进行相应读写操作. 2. file参数表示的需要打开文件的相对路径(当前 ...
- python file文件操作--内置对象open
说明: 1. 函数功能打开一个文件,返回一个文件读写对象,然后可以对文件进行相应读写操作. 2. file参数表示的需要打开文件的相对路径(当前工作目录)或者一个绝对路径,当传入路径不存在此文件会报错 ...
- 「Python」字符串操作内置函数
目录: capitalize casefold center count encode decode endswith expandtabs find format format_map index ...
- 使用R内置函数操作数据框
我们已经学习了数据框的基础,这里回顾一下用于筛选数据框的内置函数.尽管数据框本质上是一个由向量构成的列表,由于各列长度相同,所以可以将其看作矩阵进行访问和操作.选择满足特定条件的行,需要为 [ ] 的 ...
- 【原创】Matlab.NET混合编程技巧之找出Matlab内置函数
本博客所有文章分类的总目录:[总目录]本博客博文总目录-实时更新 Matlab和C#混合编程文章目录 :[目录]Matlab和C#混合编程文章目录 Matlab与.N ...
- Matlab.NET混编技巧之——找出Matlab内置函数
原文 http://www.cnblogs.com/asxinyu/p/3295309.html Matlab与.NET的混合编程,掌握了基本过程,加上一定的开发经验和算法基础,肯 定不难.反之,有时 ...
- Matlab.NET混合编程技巧之——找出Matlab内置函数
原文:[原创]Matlab.NET混合编程技巧之--找出Matlab内置函数 Matlab与.NET的混合编程,掌握了基本过程,加上一定的开发经验和算法基础,肯定不难.反之,有时候一个小错误,可能抓破 ...
- Matlab内置函数
[原创]Matlab.NET混编技巧之——找出Matlab内置函数 Matlab与.NET的混合编程,掌握了基本过程,加上一定的开发经验和算法基础,肯定不难.反之,有时候一个小错误,可能抓破脑袋, ...
- python语法基础-函数-内置函数和匿名函数-长期维护
################## 内置函数 ####################### """ 一共是 68个内置函数: 反射相关的内置函 ...
- set、def、lambda、内置函数、文件操作
set : 无序,不重复,可以嵌套 .add (添加元素) .update(接收可迭代对象)---等于批量 添加 .diffrents()两个集合不同差 .sysmmetric difference( ...
随机推荐
- 【Python实践-7】输出100以内的所有素数
#输出100以内的所有素数,素数之间以一个空格区分(注意,最后一个数字之后不能有空格). i= l=[] : k= ,i): : k=k+ : l.append(i) i=i+ print(" ...
- 20155206 Exp5 MSF基础应用
20155206 Exp5 MSF基础应用 基础问题 . 用自己的话解释什么是exploit,payload,encode . exploit:这个词本身只是利用,但是它在黑客眼里就是漏洞利用.有漏洞 ...
- 20155237方自晨 实验四android开发基础
提交点一 Android Stuidio的安装测试: 参考<Java和Android开发学习指南(第二版)(EPUBIT,Java for Android 2nd)>第二十四章: 安装 A ...
- 2017-2018-2 《网络对抗技术》20155322 Exp9 web安全基础
[-= 博客目录 =-] 1-实践目标 1.1-实践介绍 1.2-实践内容 1.3-实践要求 2-实践过程 2.1-HTML 2.2-Injection Flaws 2.3-XSS 2.4-CSRF ...
- 2017-2018-2 20155333 《网络对抗技术》 Exp1 PC平台逆向破解
2017-2018-2 20155333 <网络对抗技术> Exp1 PC平台逆向破解 1. 逆向及Bof基础实践说明 1.1 实践目标 本次实践的对象是一个名为pwn1的linux可执行 ...
- [Oracle]OpenVMS 运行 Oracle 时的推荐值
PQL Parameters ORACLE Account ------------------ ------------------------- PQL_M ...
- EAS_BI(扩展报表)
case when 的使用 1. 扩展报表,一张收费单据中,下面分为分录 问题描述: 收费单中有一个分录用于记录检测的项目名称以及标准费用.收费单有自己的主键,分录中的外键即是收费单的主键,然后分录表 ...
- Partition4:增加分区
在关系型 DB中,分区表经常使用DateKey(int 数据类型)作为Partition Column,每个月的数据填充到同一个Partition中,由于在Fore-End呈现的报表大多数是基于Mon ...
- 华为测试大牛Python+Django接口自动化怎么写的?
有人喜欢创造世界,他们做了开发者:有的人喜欢开发者,他们做了测试员.什么是软件测试?软件测试就是一场本该在用户面前发生的灾难提前在自己面前发生了,这会让他们生出一种救世主的感觉,拯救了用户,也就拯救者 ...
- ats反向代理和重定向
作为反向代理缓存,ats代表源服务器提供的请求. ats的配置方式使客户端看起来像普通的原始服务器. 了解反向代理缓存通过转发代理缓存, ats代表请求内容的客户端队里对源服务器的web请求.反向代理 ...