python基础-第四篇-4.2文件操作

基本打开模式

  • 文件操作的流程:打开文件,操作文件,关闭文件
  • 打开文件方法:open(文件名,模式,编码)
  • file = open(‘文件名’) 模式在不给值的情况下,默认为只读,而且如果是非当前的目录下文件名要加绝对路径

  

  ‘r’--只读

  • file_name.read()   一次性把指针后的内容全部读出来

  

  • file_name.readlines()  把指针后内容,以列表的形式每行读出

f = open(‘ha.log‘,‘r‘)
data1 = f.readlines()
f.close()
print(data1)
#结果为:[‘that is good!\n‘, ‘nice to meet you!\n‘, ‘hello kitty!\n‘]

f = open(‘ha.log‘,‘r‘)
f.seek(5)
data2 = f.readlines()
f.close()
print(data2)
#结果为:[‘is good!\n‘, ‘nice to meet you!\n‘, ‘hello kitty!\n‘]
  • file_name.readline()  每一次读一行内容

  

  • 文件里循环读取,循环文件默认是循环行内容
f = open(‘ha.log‘,‘r‘)
for line in f:
    print(line)
f.close()
#结果为:
        that is good!

        nice to meet you!

        hello kitty!

 ‘r‘模式总结:只读模式在打开文件时是从头开始读,其中read()和readlines()是一次把文件所有内容都读取出来,在文件很大时,不建议这两种方法,非常占内存

       而readline和循环文件是一行一行读,两次方法每次读取都是只占一行内容的内存,readline操作比较繁琐,并且你如果不知道最后一行在哪,一般容易报错,

       一般用for循环

  ‘w’--只写

  • 以只写模式打开时,先检测文件存不存在,不存在就创建,存在清空文件内容

  

  • file_name.writelines()  和只读里的readlins相对应,以列表形式写入
f = open(‘ha.log‘,‘w‘)
f.writelines([‘that is good!\n‘, ‘nice to meet you!\n‘, ‘hello kitty!\n‘])
f.close()

f = open(‘ha.log‘,‘r‘)
data = f.read()
f.close()
print(data)
结果为:
        that is good!
        nice to meet you!
        hello kitty!

  ‘w’模式总结:只写模式适用于创建不存在的文件,用于清空内容再写入内容情况比较少,如果说想在文件末尾添加内容,这就涉及到我们即将讲的‘a’模式

  ‘a’--追加模式

  • 打开文件时,指针跳到文件的末尾,此时执行写操作就是内容添加操作
  • 追加模式下不可读,不存在则创建,存在则追加
f = open(‘ha.log‘,‘a‘)
print(f.tell())
f.write(‘大家好‘)
f.close()

f = open(‘ha.log‘,‘r‘)
data = f.read()
f.close()
print(data)
结果为:
        48
        that is good!
        nice to meet you!
        hello kitty!
        大家好

  ‘x’--只写

  • 不存在创建,存在则报错(这个模式py3新增的)    --用于判断文件存不存在非常有用

  

字节打开模式

  • 别看我们平时操作都是能看懂的字符串,其实在程序底部都是一些计算机能识别的二进制文件,所以让我们看懂,必须经过一个编码转换区,由字节转换为字符

  

  ‘rb‘--字节只读模式

  

  ‘wb‘--字节只写模式

  

文件操作指针

  • file_name.seek()  指针拨到指定位置
  • file_name.tell()  告诉你当前指针的位置

  

  • r+ 读写--从0开始
  • w+ 写读--写把文件清空,从0开始
  • a+ 写读--指针从末尾开始
  • x+ 写读--存在报错,从0开始

  

  

with open(‘ha.log‘,‘w‘) as f:
    f.writelines([‘大家好才是真的好\n‘,‘明天的太阳依旧灿烂\n‘])

#打开以a+模式,如果先写,是从当前指针开始往后覆盖内容
with open(‘ha.log‘, ‘r+‘) as f:
    print(f.tell())  #0
    f.write(‘早起的鸟儿有虫吃\n‘)
    f.seek(0)
    data3 = f.read()
    print(data3)
# 结果为:
#     早起的鸟儿有虫吃
#     明天的太阳依旧灿烂

文件上下文管理

  • with open(’文件名‘,模式) as 文件变量:文件操作---------这种方式不用再写文件关闭了,因为这种方式在操作后会自动关闭文件
  • 在py3还支持同时打开两个文件:with open(文件1,模式) as obj1,open(文件2,模式) as obj2:文件操作

  大型文件复制:

with open(‘ha.log‘,‘r‘) as obj1,open(‘ha2.log‘,‘w‘) as obj2:
    for line in obj1:
        obj2.write(line)

with open(‘ha2.log‘,‘r‘) as obj2:
    data = obj2.read()
    print(data)

文件操作常用方法拾遗

  • file_name.flush()  强行把内存刷到硬盘
  • file_name.truncate()  保留指针前的内容
with open(‘ha2.log‘,‘a+‘) as obj1:
    obj1.seek(6)
    obj1.truncate()
    obj1.seek(0)
    data = obj1.read()
    print(data)  #结果为:大家好
时间: 2024-10-29 19:11:38

python基础-第四篇-4.2文件操作的相关文章

Python基础第四篇—模块

一.模块 模块,是用一堆代码实现了某个功能的代码集合,模块分为三种:自定义模块(自己定义).内置模块(python自带).开源模块 导入模块 (1).导入一个py文件,解释器解释该py文件 (2).导入一个包,解释器解释该包下的 __init__.py 文件 #模块导入 import module from module.xx import xx from module.xx.xx import * from module.xx.xx import xx as rename #自己给模块定义一个

python 基础第四篇

今日大纲: 1. list(增删改查) 列表可以装大量的数据. 不限制数据类型. 表示方式:[] 方括号中的每一项用逗号隔开列表和字符串一样.也有索引和切片常用的功能: 增: append() 删:remove() 改: 索引修改 查: for循环 常用方法: len() count() sort() 排序 2. list的嵌套降维操作3. tuple 元组不可变的列表. 只读列表. 有索引和切片.不可变的是它内部子元素. 如果子元素是列表. 列表中的元素是可以变的.4. range()数数有一

Python基础教程系列:九、文件操作

一.open()函数 open()以及file()(open()与file()等价,可以任意替换)提供了初始化输入/输出(I/O)操作的通用接口.open()函数成功打开一个文件后就会返回一个文件对象,说白了你就可以接着读写了,否则就bug了. 语法:file_object = open(file_name, access_mode='r', buffering=-1) 第一个参数是文件名或者路径(绝对或相对路径),第二个参数叫文件打开的模式,不写时默认是'r'模式.'r'模式是只读模式.'w'

python、第四篇:记录相关操作

一 介绍 MySQL数据操作: DML ======================================================== 在MySQL管理软件中,可以通过SQL语句中的DML语言来实现数据的操作,包括 使用INSERT实现数据的插入 UPDATE实现数据的更新 使用DELETE实现数据的删除 使用SELECT查询数据以及. ======================================================== 本节内容包括: 插入数据更新

Python 基础语法(四)

Python 基础语法(四) --------------------------------------------接 Python 基础语法(三)-------------------------------------------- 十.Python标准库 Python标准库是随Pthon附带安装的,包含了大量极其有用的模块. 1. sys模块 sys模块包含系统对应的功能 sys.argv ---包含命令行参数,第一个参数是py的文件名 sys.platform ---返回平台类型 sy

Python基础知识(四)

Python基础知识(四) 一丶列表 定义格式: 是一个容器,由 [ ]表示,元素与元素之间用逗号隔开. 如:name=["张三","李四"] 作用: 存储任意类型的数据 (32位机器能存5亿多,64为机器存储更多) 特点: 可变 (增,删,改,查) 默认从左到右 ,从0开始 . 有序(索引,切片,步长) 操作: 增 , 删 , 改 ,查 ,索引,切片,步长 ?? #列表的两种定义方式 name=["香蕉","西瓜",&quo

php基础知识总结(2)文件操作file

一.路径 1.dirname -- 返回路径中的目录部分      $path = "/etc/passwd";      $file = dirname($path); // "/etc" 2.basename -- 返回路径中的文件名部分     $path = "/home/httpd/html/index.php";     $file = basename($path);        // index.php     $file =

Python基础篇【第七篇】:文件操作

open函数 用于文件处理,使用方式: #file = open('文件路径','操作方式','指定以什么字符集方式打开') file = open("ha.log",'r',encoding='utf-8') 操作方法: 序号 方法及描述 1 file.close() 关闭文件.关闭后文件不能再进行读写操作. 2 file.flush() 刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入. 3 file.fileno() 返回一个整型的文件描述符

Python基础第三篇

一.collections系列 Counter是对字典类型的补充,用于追踪值的出现次数,具备字典的所有功能 + 自己的功能 1.计数器Counter import collections a='abababsbsbhh' c=collections.Counter(a) #直接列出每个元素出现了几次,传入列表和元组也一样 print(c) #输出:Counter({'b': 5, 'a': 3, 'h': 2, 's': 2}) #most_common 列出Counter内的前几个 print