zoukankan      html  css  js  c++  java
  • 68.文件的读写

    文件的读写

    <1>写数据(write)

    使用write()可以完成向文件写入数据

    demo: 新建一个文件 file_write_test.py,向其中写入如下代码:

    f = open('test.txt', 'w')
    f.write('hello world, i am here!')
    f.close()

    运行之后会在file_write_test.py文件所在的路径中创建一个文件test.txt,其中数据如下:

     

    注意:

    • 如果文件不存在那么创建,如果存在那么就先清空,然后写入数据

    <2>读数据(read)

    使用read(num)可以从文件中读取数据,num表示要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就表示读取文件中所有的数据

    demo: 新建一个文件file_read_test.py,向其中写入如下代码:

    f = open('test.txt', 'r')
    content = f.read(5)  # 最多读取5个数据
    print(content)
    
    print("-"*30)  # 分割线,用来测试
    
    content = f.read()  # 从上次读取的位置继续读取剩下的所有的数据
    print(content)
    
    f.close()  # 关闭文件,这个可以是个好习惯哦

    运行现象:

    hello
    ------------------------------
     world, i am here!

    注意:

    • 如果用open打开文件时,如果使用的"r",那么可以省略,即只写 open('test.txt')

    <3>读数据(readlines)

    就像read没有参数时一样,readlines可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素

    #coding=utf-8
    
    f = open('test.txt', 'r')
    content = f.readlines()
    print(type(content))
    
    i=1
    for temp in content:
        print("%d:%s" % (i, temp))
        i += 1
    
    f.close()

    运行现象:

    <4>读数据(readline)

    #coding=utf-8
    
    f = open('test.txt', 'r')
    
    content = f.readline()
    print("1:%s" % content)
    
    content = f.readline()
    print("2:%s" % content)
    
    
    f.close()

    想一想:

    如果一个文件很大,比如5G,试想应该怎样把文件的数据读取到内存然后进行处理呢?

     文件的写入数据:

    例子1:

    # w权限
    # 使用w权限打开文件 先对文件的数据清空
    # 打开文件
    f = open("hm.txt", "w")
    # # 写入数据
    f.write("456")
    f.write("hello")
    # # 关闭文件
    f.close()

    例子2:

    # a权限
    # 使用a权限打开文件 在原来的数据上进行追加数据
    # 打开文件
    f = open("hm1.txt", "a")
    # # 写入数据
    f.write("123")
    # # 关闭文件
    f.close()

    例子3:

    # 如果在windows系统中 使用文件写入中文
    # 编码格式: utf-8 ascii gbk (unicode -万国码) ->升级版 -> utf-8
    # 美国人 97 -> a
    # 中国人 97 -> 中
    # unicode a->1 中->2
    # encode -> 编码
    # decode -> 解码
    # 打开文件
    f = open("hm2.txt", "w", encoding="utf-8")
    # 写入中文
    f.write("中国123hello")
    # 关闭文件
    f.close()

    文件的读取数据:

    例子1:

    # <2>读数据(read)
    # 文件名.read() 把文件的数据全部读取出来
    # 文件名.read(n) 每次读取文件中的n个字符
    
    # 打开文件
    f = open("hm.txt", "r")
    # 读取文件的数据
    ret = f.read()
    print(ret)
    # 关闭文件
    f.close()

    例子2:

    # <2>读数据(read)
    # 文件名.read() 把文件的数据全部读取出来
    # 文件名.read(n) 每次读取文件中的n个字符
    
    # 打开文件
    f = open("hm.txt", "r")
    # 读取文件的数据
    ret = f.read(3)
    print(ret)
    ret = f.read(3)
    print(ret)
    # 关闭文件
    f.close()

    例子3:

    # <3>读数据(readlines)
    # 打开文件
    f = open("hm.txt", "r")
    # 读取数据
    ret = f.readlines()
    print(ret)
    # 关闭文件
    f.close()

    例子4:

    # <4>读数据(readline)
    # 打开文件
    f = open("hm.txt", "r")
    # 读取数据
    ret = f.readline()
    print(ret)
    ret = f.readline()
    print(ret)
    # 关闭文件
    f.close()
  • 相关阅读:
    高斯消元(模板及bitset优化异或方程)
    dsu on tree
    拉格朗日插值
    [CF] CF900D Unusual Sequences
    【模板】Polya 定理
    Min-25筛学习笔记
    [CF] CF156C Cipher
    基于 Flink + Kafka 的广告实时数据分析建设与实践
    开源中国【面经】Java后台开发
    spring boot中连接数据库报错500(mybatis)
  • 原文地址:https://www.cnblogs.com/kangwenju/p/12854232.html
Copyright © 2011-2022 走看看