一、文本文件基本操作

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----操作文本文件的更多相关文章

  1. 使用python操作json文本文件

    使用python读写文本文件内容时,我们知道如果文本文件里的内容无规律,那么修改起来比较麻烦.但是如果文本文件存储是有规律的,比如JSON格式,在利用python内置的函数把JSON格式的数据转成py ...

  2. Python中文本文件读写操作的编码问题

    Python中文本文件读写的编码问题 编码(encode): 我们输入的任何字符想要以文件(如.txt)的形式保存在计算机的硬盘上, 必须先经按照一定的规则编成计算机认识的二进制后,才能存在电脑硬盘上 ...

  3. Python操作数据库之 MySQL

    Python操作数据库之MySQL 一.安装Python-MySQLdb模块 Python-MySQLdb是一个操作数据库的模块,Python 通过它对 mysql 数据实现各种操作. 如果要源码安装 ...

  4. python + docker, 实现天气数据 从FTP获取以及持久化(二)-- python操作MySQL数据库

    前言 在这一节中,我们主要介绍如何使用python操作MySQL数据库. 准备 MySQL数据库使用的是上一节中的docker容器 “test-mysql”. Python 操作 MySQL 我们使用 ...

  5. python - 操作excel表格

    说明:由于公司oa暂缺,人事妹子在做考勤的时候,需要通过几个excel表格去交叉比对员工是否有旷工或迟到,工作量大而且容易出错. 这时候it屌丝的机会来啦,花了一天时间给妹子撸了一个自动化脚本. 1. ...

  6. 数据备份 及 Python 操作 Mysql

    一 MySQL数据备份 #1. 物理备份: 直接复制数据库文件,适用于大型数据库环境.但不能恢复到异构系统中如Windows. #2. 逻辑备份: 备份的是建表.建库.插入等操作所执行SQL语句,适用 ...

  7. 用Python操作excel文档

    使用Python第三方库 这一节我们学习如何使用Python去操作Excel文档.如果大家有人不知道Excel的话,那么建议先学一学office办公基础.这里想要操作Excel,必须安装一个Pytho ...

  8. Python(九) Python 操作 MySQL 之 pysql 与 SQLAchemy

    本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...

  9. Python 【第六章】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

    Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...

  10. 练习:python 操作Mysql 实现登录验证 用户权限管理

    python 操作Mysql 实现登录验证 用户权限管理

随机推荐

  1. 解决Kettle ETL数据乱码

    首先用insert语句插入一条数据试试是否因为MySQL编码不对引起,如果是MySQL原因,修改MySQL编码即可: 如果不是因为MySQL的编码导致问题,那么在Kettle的表输出中,编辑连接-选项 ...

  2. 消息服务jms

    jms是java消息服务的规范,也即接口,activemq是实现.队列模型和发布订阅模型很像,区别就是队列,多个消费者消费不同的消息(这些消费者整体消费完生产者生产的队列的消息),发布订阅模型是多个消 ...

  3. Number 强制类型转换 int 强制转换整型 float 强制转换浮点型 complex 强制转换成复数 bool 强制转换成布尔类型,结果只有两种,要么True 要么 False """bool 可以转换所有的数据类型 everything"""

    # ###Number 强制类型转换 var1 = 5 var2 = 4.85 var3 = True var3_2 = False var4 = 3+9j var5 = "888777&q ...

  4. sklearn countvectorizer坑

    但是如果修改为['驴 福 记 ( 阜通 店 )','...',...]执行vectorizer.fit_transform就正常.原因是,创建CountVectorizer实例时,有一个默认参数ana ...

  5. 使用AMBER中遇到的一些问题

    1.读取蛋白问题 读取无配体pdb文件(loadpdb complex.pdb)时,出现一堆 FATAL: Atom .R<ARG >.A<HD1 > does not hav ...

  6. python模拟面试技术题答案

      目录 Python4期模拟面试技术面试题答案............................................................................ ...

  7. <转>jmeter(二十二)内存溢出原因及解决方法

    本博客转载自:http://www.cnblogs.com/imyalost/category/846346.html 个人感觉不错,对jmeter讲解非常详细,担心以后找不到了,所以转发出来,留着慢 ...

  8. Linux 磁盘分区管理

    Linux 磁盘管理进阶 磁盘分区介绍 基本分区(primary partion) 基本分区也称主分区,引导分区.每块磁盘分区主分区与扩展分区加起来不能大于四个. 基本分区创建后可以立即使用,但是有分 ...

  9. JS设计模式(2)策略模式

    什么是策略模式? 定义:根据不同参数可以命中不同的策略 主要解决:在有多种算法相似的情况下,使用 if...else 所带来的复杂和难以维护. 何时使用:有许多种情况,而区分它们的只是他们直接的行为. ...

  10. UVA11992 Fast Matrix Operations

    思路 注意到最多20行,拆成20颗线段树即可 注意set标记清空左右儿子的add,不要清空自己的add,因为这个set操作之后可能还有add存在这个节点上 代码 #include <cstdio ...