文件操作,内置函数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( ...
随机推荐
- 使用clipboard插件实现div、textarea、input里面的内容复制到粘贴板
一.引用clipboard的js文件 二.编写代码.data-clipboard-action=“copy”,代表要执行的动作是复制.data-clipboard-target里面要是要选择复制的元素 ...
- Selenium-Switch与SelectApi接口详解
Switch 我们在UI自动化测试时,总会出现新建一个tab页面.弹出一个浏览器级别的弹框或者是出现一个iframe标签,这时我们用WebDriver提供的Api接口就无法处理这些情况了.需要用到Se ...
- Hadoop框架
1.Hadoop的整体框架 Hadoop由HDFS.MapReduce.HBase.Hive和ZooKeeper等成员组成,其中最基础最重要元素为底层用于存储集群中所有存储节点文件的文件系统HDFS( ...
- win10安装tensorflow-gpu
1.安装anaconda (最好使用清华源下载) 2.打开cmd conda create -n tensorflow pip python=3.6 activate tensorflow pip i ...
- 自己动手写Impala UDF
本文由 网易云发布. 概述 出于对可扩展性和性能的考虑,UDF已变成大数据生态圈查询引擎的必备功能之一,无论是Calcite.Hive.Impala都对其进行支持,但是UDF的支持有利也有弊,好处在 ...
- redis 事务,持久化,日志,主从,VM
redis目前对事务的支持比较简单,只能保证一个客户端连接发起事务中的命令可以连续执行,而中间不会插入其他客户端的命令. 1.事务 一般情况下,redis接收到一个客户端发送的命令,立刻执行并返回结果 ...
- 《Toward an SDN-Enabled Big Data Platform for Social TV Analysis》--2015--Han Hu
<面向应用于社会TV分析的应用了SDN的大数据平台> Abstract social TV analytics 是什么,就是说很多TV观众在微博.微信和推特等这些地方分享他们的观感时,然后 ...
- Beta冲刺——day5
Beta冲刺--day5 作业链接 Beta冲刺随笔集 github地址 团队成员 031602636 许舒玲(队长) 031602237 吴杰婷 031602220 雷博浩 031602134 王龙 ...
- Xshell登录Docker
使用SSH协议登录即可,用户名为docker,密码为tcuser
- Docker(二十二)-Docker Swarm常用命令
#查看集群节点 docker node ls #创建nginx服务 #docker pull hub.test.com:5000/almi/nginx:0.1 #下载私有仓库镜像 docker ser ...