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 实现登录验证 用户权限管理
随机推荐
- PHP自定义curl请求
function http_post($url,$param,$post_file=false,$headers=[]){ $oCurl = curl_init(); if(stripos($url, ...
- PHP Echarts Ajax Json柱形图示例
<?php $server = '127.0.0.1'; $user = 'root'; $password = ''; $database = 'yiibaidb'; $conn = new ...
- Oracle 11g R2创建数据库之手工建库方式
在之前的博文当中梳理了关于DBCA静默方式创建数据库的过程,本文就手工通过SQL*PLUS客户端采用CREATE DATABASE语句创建数据库.这种建库方式就是完全使用手工SQL语句创建数据库,通常 ...
- C工程 交互 ceph 分布式存储系统
网上看到有人问,如何在C项目里调用ceph系统对外提供的API,实现分布式存储. 我在网上搜到了相关信息,但是因为不是会员无法追加答案,故而,贴于此. 赠予有缘人:) ———————————————— ...
- js实现多行文本溢出省略
实现效果: css: position: relative; line-height: 20px; max-height: 60px; js: function overflowHiddon(el) ...
- python_MySQL
原文章连接:http://www.runoob.com/python/python-mysql.html 配置数据库 conn = mysql.connector.connect(user='root ...
- SV coverage
covergroup是对coverage model的一种包装,每个covergroup可以包含: 1) sync event来触发采样, 2) 很多coverpoint, 3) cross cove ...
- Godot必须明确掌握的概念与知识
本文对godot必须掌握的概念进行罗列,以便于浏览学习: (随时补充) 1.场景 2.节点 X:场景与节点 3.脚本(建议直接学习GDscript,当然掌握C#也可以) 4.类
- 浅探网络1---tcp协议详解(三次握手和四次挥手)
TCP协议是网络多层协议中运输层的最重要的协议之一,运输层是两台主机的进程之间的通信.除了TCP还有一个是UDP协议(用户数据包协议) TCP全称是Transmission Control Proto ...
- jQuery 筛选器2
jQuery 筛选器2 // 由于$()只能输入字符串$('#li:eq(1)'),可通过.eq()来传入. // 获取this标签中的指定属性 $(this).eq(1) // 获取第一个元素 $( ...