美文网首页
day11-文件操作总结

day11-文件操作总结

作者: 哗啦噼里啪啦 | 来源:发表于2018-11-19 19:22 被阅读0次

    a.迭代器: 容器,可以同时存储多个数据,取的时候只能一个一个的取,并且取过的数据在容器中就不存在了
    b.生成器: 就是迭代器, 数据是通过调用函数,获取yield后面的值而产生的。数据会在获取的时候去产生
    调用一个带yield关键的函数,就是创建一个生成器。
    注意:表达式的结果就是每次循环生成器产生的数据
    这儿的for循环可以控制生成器产生数据的个数,和产生的值

    表达式  for 变量  in 序列:
    展开        def func():
                        for 变量 in序列:
                                yield 表达式
    gen1=x   for  x  in  range(4):
                           yield x 
    print(next(gen1))  #0
    print(next(gen1))# 1
    print(next(gen1))#2
    print(next(gen1))#3
    
    gen1=x*10 for x in range(4):
                         yield x*10
    print(next(gen1))  #0
    print(next(gen1))# 10
    print(next(gen1))#20
    print(next(gen1))#30
    
    格式2:
    (表达式 for 变量 in 序列 if 条件语句)  --> 展开:
                                            def func1():
                                                for 变量 in 序列:
                                                    if 条件语句:
                                                        yield 表达式
    gen1= (x  for  x  in  range(4)  if x %2)
    print(next(gen1))#1
    print(next(gen1))#3
    gen2=(x  for  x in  range(4) if x%2==0 )
    print(next(gen2)) #0
    print(next(gen2))#2
    

    交换字典键值对

    dict1 = {'a': 1, 'b': 2, 'c': 3}
    dict2=dict((value,key) for key,value in dict1.items())
    print(dict2)-->{1:'a' , 2:'b' 3:'c'}
    

    模块的使用

    1.什么是模块
    python中一个py文件就是一个模块

    2.怎么关联多个模块
    方式1:
    import 模块名 - 将指定的模块导入到当前模块中,导入所有的全局变量(模块名就是py文件的文件名)
    说明:
    a.执行import的时候,实质会进入指定的模块对应的py文件中,去执行里面的代码
    b.import导入模块的时候,会检测当前模块之前是否已经导入过,如果已经导入过就不再导入
    c.通过import去导入一个模块后,可以通过 模块名.全局变量 去使用被导入的模块中的内容

    import test1
    使用test1中的变量
    a = test1.test1_a
    print('当前模块:', a)
    
     调用test1中的函数
    test1.test1_func1()
    

    方式2:
    from 模块名 import 变量名/函数名 - 导入模块中指定的变量或者函数
    说明:
    a. 执行到导入模块的语句的时候,还是会先执行指定模块中的所有语句
    b. 通过from-import导入的时候,导入多次还是只执行一次(查重)
    c. 使用的时候只能用import后面的变量/函数,而且用的时候不用在前面加模块名
    d. import后面可以使用逗号将多个变量/函数隔开。也可以使用*将模块中的所有的全局变量一起导入

    from test2 import test2_a, test2_func1
    from test2 import *       # 同时倒入test2中所有的全局变量
    from test1 import test1_a
    print('当前模块', test2_a)
    test2_func1()
    

    函数 - 对功能进行封装 - 获取当前时间对应的代码封装到函数中
    模块 - 对多个功能和多个数据进行封装 - 将所有和时间相关的函数或者变量放到一个py文件中
    包 - 对多个模块进行封装 - 将所有和时间相关的py文件放到一个文件夹中
    什么是包: 含有init.py文件的文件夹

    3.重命名
    import 模块名 as 新模块名
    from 模块名 import 变量名 as 新变量名

    sdf  as  ttf
    from asdf  import   as ttf
    

    4.包的导入
    import 包名 - 会直接执行包中的init.py文件中的代码
    import 包名.模块名 - 导入指定包中的执行模块

    from 包名 import 模块名
    from 包名.模块名 import 变量

    from test import my_test
     print(my_test.aaa)
    from test.my_test import aaa
    

    在模块中将不需要其他模块导入和执行的代码写到 if name == 'main'语句中。
    这样就可以阻止代码被其他模块执行

    原理:每个模块都有一个name属性,默认值是模块对应的py文件的名字。
    当正在直接执行模块的时候,模块的name属性值就会变成'main'。
    当import模块的时候,执行模块,模块的name属性不是'main'

    数据本地化

    将数据以文件的形式,存储到本地磁盘中。
    (程序中变量保存的数据都是存到内存中的,当程序运行结束内存中的数据会销毁)

    常见的数据本地化方式:二进制文件(包含音频,视频,压缩包等), 普通文本文件, json和xml文件, 数据库文件等

    2.文件操作(读和写)
    文件操作的固定步骤:打开文件(新建文件) - 文件操作(读和写) - 关闭文件

    3.打开文件
    open(file, mode='r',...,encoding=None) - 返回的是被打开的文件对象(文件句柄)

    说明:
    file - 字符串;需要打开的文件的路径(可以是绝对路径,也可以是相对路径)
    (一般不使用)绝对路径: /Users/yuting/Workspace/JAVA/授课/python1808/day11-文件操作/files/蓝莲花.txt
    相对路径:(相对当前的py对应的目录)
    ./ -- 当前目录(./可以省略) aaa.txt ./aaa.txt
    ../ -- 当前目录的上层目录
    .../ -- 当前目录的上上层目录

    mode - 打开方式; 打开文件后不同的操作,对应的打开方式不一样
    'r' - 默认值,以读的方式打开文件, 读出来的是字符串
    'w' - 以写的方式打开文件
    'rb'/'br' - 以读的方式打开,读出来的数据是二进制
    'wb'/'bw' - 以写的方式打开,写二进制数据到文件中
    'a' - 以写的方式打开,追加
    '+' - 以读写方式打开

    encoding - 文本文件编码方式,一般赋值为'utf-8'
    utf-8 - 支持中文编码
    gbk - 不支持中文编码

    以读的形式打开一个文本文件,保存到变量f中。对f进行操作,就是对被打开的文件进行操作

    f= open ('asd.txt', 'r' ,encoding='utf-8')
    

    4.文件的读操作
    文件对象.read() - 从文件读写位置开始读到文件结尾(默认就是获取文件中所有的内容)
    文件对象.readline() - 读一行内容

     读文件所有的内容
    content = f.read()
     print(content)
    
    读一行
    content = f.readline()
    print('===:',content)
    

    将文件中的内容读完,要求一行一行的读

    count=f.readline
    while count:
          print(count)
    

    5.文件的写操作
    文件对象.write(字符串) - 将字符串中的内容写入到文件中(会完全覆盖原文件中的内容)
    'w' - 完全覆盖
    'a' - 在原文件的最后添加

    f = open('asdf.txt', 'a', encoding='utf-8')
    f.write('你好吗?')
    

    6.关闭文件
    文件对象.close() - 关闭指定的文件

    二进制文件的读写操作

    with open ('asd.txt', encoding='utf-8')
    'asd.txt'.close()
    

    普通的文本文件,也可以以二进制的形式读和写

    1. 二进制文件的读写
      只要将读写方式设置为 'rb'/'br'就可以了。读出来的数据直接就是二进制数据
      注意:二进制操作不能设置编码方式
    二进制文件的读
    with open('asd.txt', 'rb') as f:
        content = f.read()
        print(content, type(content))
    
    with open('./284c1c3387c24028915fc3d6.jpg', 'rb') as f:
        content = f.read()
        print(content)
    
    二进制文件的写
    with open('./284c1c3387c24028915fc3d6.jpg', 'wb') as f:
        f.write(content)
    
    with open('./284c1c3387c24028915fc3d6','wb')as f :
        f.write(conetd)
    

    3.文件不存在
    当以读的方式打开一个不存在的文件,会报'FileNotFindError'
    当以写的方式打开一个不存在的文件,不会报错,并且会创建这个文件

    with open('ddd.txt', 'bw') as f:
        # print(f.write())
        pass
    

    指导思想:
    1.使用数据的时候去本地文件中取数据
    2.数据修改后,将新的数据更新到本地文件中

    写一个程序统计当前程序执行的次数。第一次运行程序打印1,第二次运行的时候打印2,以此类推

    count = 1
     print(count)
    count += 1
    with open('files/count.txt', encoding='utf-8') as f:
        count = int(f.read())    # 读到的是字符串
        # print(count)
        print('第%d次进入程序' % count)
    
    让次数加1
    count += 1
    with open('files/count.txt', 'w', encoding='utf-8') as f:
        以'w'方式打开,
    

    相关文章

      网友评论

          本文标题:day11-文件操作总结

          本文链接:https://www.haomeiwen.com/subject/lniafqtx.html