python文件的读写追加等操作
# encoding:utf-8
# 文件读取操作
fp=open("E:\\file.txt","r",encoding="utf-8" )
data_read=fp.read()#一次性全部读完
fp.seek(0,0)#游标移动到第一行,继续读,否则读取到的是空
data_readlines=fp.readlines()
fp.close()
print(data_readlines)
print(data_read)
# 练习:统计文件中一行存在test的行数
# 注:文件读取的时候,行的末尾包含回车换行符号\n
# 如果文件很大用readlines读取,小文件直接用read读取,read读取的是整个文件内容,readlines结果是list
count=0
fp=open("e:\\file.txt","r",encoding="utf-8")
lines=fp.readlines()
for i in lines:
if "test" in i:
print(i)
count+=1
print(count)
# read() readlines() readline()的区别
# read()—当成一个字符串读出
# readlines()readlines返回的是列表
# readline()一行一行读文件
# 如果文件很大,用read()内存不够(如运维日志几十G)
# 用readline来读超大文件
#原则:内存在电脑中是个稀缺的资源,如果你占用大量内存,程序肯定不是最优的,小文件:read、readlines速度更快些 模式
w+:先清空所有文件内容,然后写入,然后你才可以读取你写入的内容
r+:不清空内容,可以同时读和写入内容。 写入文件的最开始
a+:追加写,所有写入的内容都在文件的最后 # a+
fp=open("e:\\file.txt","a",encoding="utf-8")
fp.write("hello python")
fp.close()
fp=open("e:\\file.txt","r",encoding="utf-8")
data=fp.read()
fp.close()
print(data)
w+
#此时不需要关闭文件,w+ 可读可写(清空再写),文件不存在就创建,r+可读可写不存在报错
fp=open("e:\\file.txt","w+",encoding="utf-8")
fp.write("hello python")
fp.seek(0,0)
data=fp.read()
fp.close()
print(data)
#此时不需要关闭文件,a+ 可读可写(末尾追加再写),文件不存在就创建,r+可读可写不存在报错
fp=open("e:\\file.txt","a+",encoding="utf-8")
fp.write("\nhello python1")#\n用来换行
fp.seek(0,0)
data=fp.read()
fp.close()
print(data)
# 关于open()的mode参数:
# 'r':读
# 'w':写
# 'a':追加
# 'r+' == r+w(可读可写,文件若不存在就报错(IOError))
# 'w+' == w+r(可读可写,文件若不存在就创建)
# 'a+' ==a+r(可追加可写,文件若不存在就创建)
# 对应的,如果是二进制文件,就都加一个b就好啦:
# 'rb' 'wb' 'ab' 'rb+' 'wb+' 'ab+' seek(offset,whence)
seek()
offset:坐标 正数表示从前向后 负数表示从后向前 0表示
最开始的游标
whence:0,1,2 0表示从文件最开始位置,0,0
1:表示从当前位置开始,基于当前的相对位置,来重置坐标。
10 seek(5,1) 10-->5,现在的坐标是15
2:表示从文件的末尾开始,做相对位置,来重置坐标
seek(-5,2)-->末尾向前数5个字符。
注意;:1和2使用基于rb模式
注意:这个文件指针的改变只是作用于'r',对'w'和'a'不会起作用,如果是'w',
那么write()永远都是从开头写(会覆盖后面对应位置的内容),是'a'的话write()就永远都是从最后开始追加。 fp=open("e:\\file.txt","rb")
data=fp.readlines()
print(fp.tell())
fp.seek(-8,1)
data1=fp.readlines()
fp.close()
print("data:",data)
print("data1:",data1)
python文件的读写追加等操作的更多相关文章
- Python文件的读写操作
Python文件的使用 要点:Python能够以文本和二进制两种形式处理文件. 1.文件的打开模式,如表1: 注意:使用open()函数打开文件,文件使用结束后耀使用close()方法关闭,释放文件 ...
- 【8】python文件的读写方法
(1).读文件的步骤: (1)打开文件 open(path,flag,encoding,[errors]) path:打开路径 flag:打开方式 r(只读) rb(二进制格式) r+(可以读写) w ...
- python文件的读写总结
读写文件是最常见的IO操作.Python内置了读写文件的函数,用法和C是兼容的. 读写文件前,我们先必须了解一下,在磁盘上读写文件的功能都是由操作系统提供的,现代操作系统不允许普通的程序直接操作磁盘, ...
- python文件的读写的模式
<1>打开文件 在python,使用open函数,可以打开一个已经存在的文件,或者创建一个新文件 open(文件名,访问模式) 示例如下: f = open('test.txt', 'w' ...
- python文件的读写权限以及相关应用read、write和文件指针
f=open('ceshi.txt','a',encoding='utf-8')r=open('ceshi.txt','r',encoding='utf-8')上面的2种写法可以用with来写:wit ...
- [ Python ] 文件的读写操作
1. 文件读写操作 读写文件是最常见的 IO 操作, Python 内置了读写文件的函数.在磁盘上读写文件的功能是由操作系统提供的,所以读写文件是请求操作系统打开一个文件对象(通常称为文件描述符),然 ...
- Python文件的读写
一.写数据 f = open("hello.txt", "w") f.write("hello world python!") f.clos ...
- 第9.9节 Python文件随机读写定位操作方法seek
类似于C语言,Python也提供了文件位置定位的操作方法seek. 一. 语法 seek(offset, whence=SEEK_SET) 语法释义: 1)offset :将文件当前操作位置移动偏移量 ...
- python文件实现增删改查操作
# coding = utf-8 import os import json import re ''' 本程序旨在将练习基础知识部分,包括: 列表,元组,字典,文件,函数,字符串等知识 实现的功能: ...
随机推荐
- JavaScript中操作数组的方法
JavaScript Array 对象 对数组操作的方法分为两种 一种是会改变原始数组的变异方法,还有一种是不会改变原始数组的非变异方法. 总结 巧记 Push() 尾部添加 pop() 尾部删除 U ...
- Cmakelists.txt中配置glfw
qt中需要用cmake编译工程,且需要用到OpenGL库glfw,如何给Cmakelist.txt配置glfw的动态链接库? 在Cmakelists.txt添: find_package(glfw3 ...
- (转)理解inode
作者:阮一峰 原文链接:http://www.ruanyifeng.com/blog/2011/12/inode.html 一.inode是什么? 理解inode,要从文件储存说起. 文件储存在硬盘上 ...
- ssh scp nc
ssh远程连接 ssh root@192.168.111.11 scp数据传输,(secure copy) 1.下载.拉取 scp root@192.168.111.11:/root/database ...
- Java练习 SDUT-1131_最大公约数与最小公倍数
C/C++训练1---最大公约数与最小公倍数 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 输入两个正整数,求它们的最 ...
- jQuery 练习 dom
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 洛谷P1546 最短网络 Agri-Net(Prim堆优化)
#include<bits/stdc++.h> using namespace std; ; const int INF=0x3f3f3f3f; inline void read(int ...
- 洛谷P1653 猴子
#include<bits/stdc++.h> using namespace std; inline void read(int &tmp) { ;char c=getchar( ...
- oracle选择最有效率的表名顺序
ORACLE的解析器按照从右到左的顺序处理FROM子句中的表名,因此FROM子句中写在最后的表(基础表 driving table)将被最先处理. 在FROM子句中包含多个表的情况下,你必须选择记录条 ...
- celery 计划任务使用
流程: 用户提交任务 --- > Celery --- > Broker 中间商(可以是数据库,redis) ---> 最后让celery 中的 worker 执行任务 1 单独使用 ...