zoukankan      html  css  js  c++  java
  • 菜鸟python---文件操作

    # 文件操作
    "萝莉小姐姐电话号"

    1.找到文件的位置
    2.双击打开
    3.进行一些操作 # r - read(读) w - write(写) a - 追加
    rb -- (读字节) wb ab r+ w+ a+
    4.关闭文件

    open() # 打开 open通过python控制操作系统进行打开文件
    file 文件的位置
    mode 默认不写就是r
    encoding 文件的编码
    f 文件句柄

    文件只能读取一次

    读操作:
    f = open("D:Python_s25day08小姐姐电话号",mode="r",encoding="utf-8")
    print(f.read()) # 全部读取
    print(f.read(3)) # 按照字符读取

    print(f.readline()) # 默认尾部有一个
    print(f.readline().strip()) # 读取一行
    print(f.readline().strip()) # 将 去除

    print(f.readlines()) #一行一行读取,全部存储在列表中

    绝对路径
    f = open(r"D:Python_s25day08 1",mode="r",encoding="utf-8")
    print(f.read())

    相对路径
    f = open("t1",mode="r",encoding="utf-8")
    print(f.read())


    路径转义:
    1."D:\Python_s25\day08\t1"
    2.r"D:Python_s25day08 1" -- 推荐使用

    路径:
    1.绝对路径 : 从磁盘(C盘)开始查找
    2.相对路径 : 相对于某个文件进行查找

    字节操作 不能指定encoding编码

    f = open("timg.jpg",mode="rb")
    print(f.read()) # 全部读取
    print(f.read(3)) # 按照字节读取
    print(f.readline()) # 按照行进行读取
    print(f.readlines())

    r和 rb的区别:
    1.r需要指定encoding,rb不需要
    2.r模式中的read(3) 按照字符读取, rb模式中的read(3) 按照字节读取

    read 和 readlines 如果文件较大时,会出现内存溢出
    解决方案:

    面试题:
    当文件交大时,使用for循环进行读取
    f = open('t1',mode="r",encoding="utf-8")
    for i in f:
    print(i.strip())

    写操作:
    w操作: -- 清空写(写的是文本)
    1.先清空文件(打开文件时清空)
    2.写入内容

    当模式为 w 和 a 时,有文件就是用当前文件,没有文件就创建一个文件

    ff = open("a1",mode="w",encoding="utf-8")
    ff.write("123") # 写的内容必须是字符串

    ff = open("a1",mode="w",encoding="utf-8")
    ff.write("我是一个字符串串") # 写的内容必须是字符串

    ff = open("a1",mode="w",encoding="utf-8")
    ff.write("[1,2,3,4] ") # 写的内容必须是字符串
    ff.write('1111 ') # 写的内容必须是字符串
    ff.write('2222 ') # 写的内容必须是字符串

    ff = open("a1",mode="w",encoding="utf-8")
    ff.write("[1,2,3,4] ") # 写的内容必须是字符串
    ff.write('1111 ') # 写的内容必须是字符串
    ff.write('2222 ') # 写的内容必须是字符串

    wb -- 清空写(写字节)
    f = open('timg.jpg',mode="rb")
    f1 = open("g1.jpg",mode="wb")
    content = f.read()
    f1.write(content)


    a -- 追加写(文本)
    f = open("b1",mode="a",encoding="utf-8")
    f.write("你好啊 ")
    f.write("我好啊 ")
    f.write("他好啊 ")
    f.write("大家好啊 ")

    ab -- 追加写(字节)
  • 相关阅读:
    [JLOI2015]有意义的字符串
    二阶常系数线性齐次递推式的特征方程
    CH1812 生日礼物
    CH1809 匹配统计
    CH1808 Milking Grid
    BZOJ4025 二分图
    BZOJ3514 GERALD07加强版
    NOI2014 魔法森林
    WC2006 水管局长数据加强版
    LG3690 【模板】Link Cut Tree 和 SDOI2008 洞穴勘测
  • 原文地址:https://www.cnblogs.com/veryFuelong/p/13357031.html
Copyright © 2011-2022 走看看