python----操作文本文件
一、文本文件基本操作
1.1 打开文本文件,得到文件句柄并赋值给一个变量
f = open('test', 'r', encoding='utf-8') # 默认打开模式为r
文件路径:相对路径、绝对路径
1)当文件和要执行的.py文件在相同目录下,直接使用文件的名称即可
2)当文件与要执行的.py文件不在相同目录下,使用绝对路径
文件的路径,需要用取消转义的方式表示: 1.使用 \\ ;2.使用 r'c:/test/test.txt'
第一种打开文件方式: 使用 \\
file1 = open('G:\\myPyTest\\2.txt', 'w', encoding='utf-8') file1.write('哈哈') file1.close()
第二种打开文件方式: 使用r 参数说明:文件路径、操作模式、编码
file2 = open(r'G:\myPyTest\1.txt', 'w', encoding='utf-8') file2.write('嘿嘿') file2.close()
open打开文件是依赖了操作系统的提供的途径
操作系统有自己的编码,open在打开文件的时候默认使用操作系统的编码
win7\8--->utf-8 mac/linux---->gbk
第三种打开文件方式:with
with open('geci','a+') as f: #打开一个文件,把这个文件的句柄付给f for line in f: pass
打开文件的模式有:
rb,【以二进制格式打开一个文件只用于只读,文件指针将放在文件开头,为默认模式】
r,只读模式【不可写,文件不存在的话会报错,文件的指针会放在文件开头,r为默认模式】
w,只写模式【不可读,文件不存在则创建,存在则清空文件内容】
a,追加模式【不可读,文件不存在则创建,存在不会清空文件内容,只在文件末尾追加内容,此时指针在文件末尾】
"+" 表示可以同时读写某个文件
r+,【可读、可写、可追加,如果打开的文件不存在,会报错,文件指针放在文件开头】
rb+,【以二进制格式打开一个文件用于读写,文件指针放在文件开头】
w+,【写读模式,使用w+的话,已经存在的文件内容会被清空,可以读到已经写入的文件内容,文件不存在则创建】
a+,【追加读写模式,文件不存在则创建,存在则只追加写入内容,指针在文件末尾】
1.2 读取文件内容
f = open('names','a+',encoding='utf-8') #打开文件 print(f.read()) #读取文件所有内容 print(f.readline()) #读取一行内容 print(f.readlines()) #是把文件的每一行放到一个list里面,元素是每行的数据,大文件时不要用,因为会把文件内容都读到内存中,内存不够的话,会把内存撑爆
二、文件操作方法
f.seek(0) #把当前文件指针指向哪,0表示将光标定位到文件开头
f.seek(10) #把光标定位到第10个字符之后 f.tell() #获取当前文件指针的位置
print(f.tell()) #输出10 f.write('爱情证书') #写入内容 写的时候传入一个str类型 f.writelines() #str list dic 元组类型(写的时候传入一个可迭代的对象) f.flush() #强制把缓冲区的数据写入磁盘 f.truncate() #清空文件内容 f.close() #关闭文件
2.1 大文件的操作方法
用上面的read()和readlines()方法操作文件的话,会先把文件所有内容读到内存中,这样的话,内存数据一多,非常卡,高效的操作,就是读一行操作一行,
读过的内容就从内存中释放了
f = open('file.txt') for line in f: print(line)
#这样的话,line就是每行文件的内容,读完一行的话,就会释放一行的内存
三、修改文件
3.1 简单粗暴直接,先清空再写入
1) 打开一个文件,获取到所有内容
2) 对内容进行修改
3) 清空原来的内容
4) 把新的内容写进去
3.2 实例
3.2.1 需求一:将文件中所有123456 修改成7890
f = open('username','a+') f.seek(0) all_str = f.read() #获取所有内容,为字符串类型 new_str = all_str.replace('','') #修改文件,将所有密码123456替换成7890 f.seek(0) f.truncate() #清空文件内容 f.write(new_str) f.close()
3.2.2 需求二:将文件中素有用户名前加上sys_
f = open('username','a+') f.seek(0) all_str = '' for s in f:#循环文件,遍历出每一行数据 new_s = 'syz_' + s all_str= all_str +new_s f.seek(0) f.truncate()#清空文件内容 f.write(all_str) f.close()
3.3 修改文件高效方式
1) 打开两个文件,a.txt a.txt.bak
2) a文件第一行,写一行到b文件中
3) 删除a文件,将b文件名称改为a文件
import os with open('words',encoding='utf-8') as fr,open('.words.bak','w',encoding='utf-8') as fw: for line in fr: new_line = line.replace('学','learn') #将文件每一行里的“学”字替换成“learn” fw.write(new_line) fw.flush() #强制将缓存区的数据写到磁盘上 os.remove('words') #删除文件 os.rename('.words.bak','words') #改名
python----操作文本文件的更多相关文章
- 使用python操作json文本文件
使用python读写文本文件内容时,我们知道如果文本文件里的内容无规律,那么修改起来比较麻烦.但是如果文本文件存储是有规律的,比如JSON格式,在利用python内置的函数把JSON格式的数据转成py ...
- Python中文本文件读写操作的编码问题
Python中文本文件读写的编码问题 编码(encode): 我们输入的任何字符想要以文件(如.txt)的形式保存在计算机的硬盘上, 必须先经按照一定的规则编成计算机认识的二进制后,才能存在电脑硬盘上 ...
- Python操作数据库之 MySQL
Python操作数据库之MySQL 一.安装Python-MySQLdb模块 Python-MySQLdb是一个操作数据库的模块,Python 通过它对 mysql 数据实现各种操作. 如果要源码安装 ...
- python + docker, 实现天气数据 从FTP获取以及持久化(二)-- python操作MySQL数据库
前言 在这一节中,我们主要介绍如何使用python操作MySQL数据库. 准备 MySQL数据库使用的是上一节中的docker容器 “test-mysql”. Python 操作 MySQL 我们使用 ...
- python - 操作excel表格
说明:由于公司oa暂缺,人事妹子在做考勤的时候,需要通过几个excel表格去交叉比对员工是否有旷工或迟到,工作量大而且容易出错. 这时候it屌丝的机会来啦,花了一天时间给妹子撸了一个自动化脚本. 1. ...
- 数据备份 及 Python 操作 Mysql
一 MySQL数据备份 #1. 物理备份: 直接复制数据库文件,适用于大型数据库环境.但不能恢复到异构系统中如Windows. #2. 逻辑备份: 备份的是建表.建库.插入等操作所执行SQL语句,适用 ...
- 用Python操作excel文档
使用Python第三方库 这一节我们学习如何使用Python去操作Excel文档.如果大家有人不知道Excel的话,那么建议先学一学office办公基础.这里想要操作Excel,必须安装一个Pytho ...
- Python(九) Python 操作 MySQL 之 pysql 与 SQLAchemy
本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...
- Python 【第六章】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy
Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...
- 练习:python 操作Mysql 实现登录验证 用户权限管理
python 操作Mysql 实现登录验证 用户权限管理
随机推荐
- ubuntu 使用dpkg手动安装deb包时发生循环依赖的解决办法
将循环依赖的所有包放到同一个命令行里一起安装,如: sudo dpkg -i libnss3-nssdb_3.28.4-0ubuntu0.14.04.4_all.deb libnss3_3.28.4- ...
- ts中的类的定义,继承和修饰符
自己搞一个ts文件 里面写代码如下,试一下就行了 /* 1.vscode配置自动编译 1.第一步 tsc --inti 生成tsconfig.json 改 "outDir": &q ...
- 强迫症犯了,忍不住赞一下slf4j包Logger.java的优雅代码
如下是slf4j-api包下的Logger接口类里其中几个方法的声明: package org.slf4j; public interface Logger { /** * Log a message ...
- linux挂载概念简述:
挂载概念简述: 根文件系统之外的其他文件要想能够被访问,都必须通过“关联”至根文件系统上的某个目录来实现,此关联操作即为“挂载”,此目录即为“挂载点”,解除此关联关系的过程称之为“卸载” 1.挂载:根 ...
- 基于Docker的GoldenGate部署
前言 Docker最近几年异常火爆,主要是因为其方便.快捷.轻量,相对于VM,它不需要占用太多资源,随时可以创建.删除,或在已有image上添加一些软件,再制作成另一个模板image供日后使用.Doc ...
- Beaglebone板子修改usb连接时的默认IP192.168.0.2
首先除了有个USB线外,你还需要一个USB转串口的线(目的是防止修改错误,无法使用原来的usb的IP地址登陆,心大的可以跳过这步直接进入重点),串口线连接方法如下图: 将USB以及串口和PC机相连 ...
- 怎样从外网访问内网CouchDB数据库
外网访问内网CouchDB数据库 本地安装了CouchDB数据库,只能在局域网内访问,怎样从外网也能访问本地CouchDB数据库? 本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Cou ...
- MySQL条件检索_WHERE
MySQL使用WHERE命令来限定数据查询条件. 语法:SELECT 属性1,属性2 FROM 表名 WHERE 条件1 OR 条件2 AND 条件3 说明:WHERE同样适用于UPDATE.DELE ...
- Java 实现追加excle文件内容
Java 实现追加excle文件内容 一.示例一:excle(.xlsx) //jar import java.io.BufferedReader; import java.io.File; impo ...
- Docker Swarm 服务版本更新与回滚
Docker Swarm 服务版本更新 环境: 系统:Centos 7.4 x64 应用版本:Docker 18.09.0 管理节点:192.168.1.79 工作节点:192.168.1.78 工作 ...