美文网首页
2018-10-14 Day 11 文件操作

2018-10-14 Day 11 文件操作

作者: EryangZ | 来源:发表于2018-10-14 21:26 被阅读0次

    1. recode

    1. 匿名函数

    格式:
    lambda 参数列表: 返回值 常用情况:函数名 = lambda 参数列表: 返回值

    匿名函数也是函数

    2. 变量的作用域

    全局变量:没有声明在函数或者类中的变量都是全局变量
    作用域从声明开始到py文件结束

    局部变量:声明在函数和类中的变量
    作用域从声明开始到函数或类结束

    关键字:
    global: 在函数中声明一个全局变量/或者想要在函数中修改全局变量的值
    nonlocal: 想要在局部的局部去修改一个局部变量的值,我们就使用nonlacal

    3. 函数作为变量

    声明函数就是在声明一个类型是function的变量。普通变量能做的事情,函数都能做

    函数名 ---> 一个函数
    函数名() ---> 调用函数,拿到的是函数的返回值

    函数作为参数 ---> 闭包的概念(以后会讲)
    函数作为返回值 ---> 装饰器(以后会讲)

    4. 函数的调用过程

    函数的调用过程是一个压栈的过程(适用于所有语言)
    调用函数时,系统会自动在栈区间开辟空间存储数据(函数的参数,函数中声明的变量), 调用结束后内存和数据会自动销毁

    a = 10
    b = 20
    
    
    def func_a (a, b):
        a, b = b, a
        print(a, b)
    
    
    func_a(a, b)
    print(a, b)
    

    5. 递归函数 ---> 自己调用自己

    循环能做的递归都能做,但是能用循环的就不要用递归(短时间内会进行内存的大量开辟和释放, 会消耗cpu)

    步骤:
    第一: 找临界值(找出循环结束的条件,这儿要让函数结束)
    第二: 找当次循环( f(n) )和上次循环( f(n-1) )的关系
    第三: 用f(n-1)去实现f(n)的功能

    2. 模块的使用

    1. 什么是模块

    python中一个py文件就是一个模块,可以通过import 模块或者from-import在一个模块中去使用另一个模块

    2. 导入模块

    import 模块名 ---> 导入模块中所有内容,并且在当前模块中通过"模块名."的方式去使用模块中的所有全局变量
    from 模块名 import 变量1, 变量2…… ---> 将模块中的所有内容都导入,但是只能使用import后导入的变量
    from 模块名 import* ---> 将模块中所有内容导入,可以直接使用模块中的全局变量

    代码执行到import的时候,会讲import模块中的代码内容执行一遍

    # import ey_module
    #
    # # 使用test1 中的整型变量
    # print(ey_module.ey_test + 100)
    
    
    
    # # 使用eryang_module中的函数eryang_func
    # ey_module.ey_func()
    # print("当前模块", ey_test)
    # print(ey_func())
    
    # # 使用*
    # from ey_module import *
    # print("当前模块", ey_test)
    # print(ey_func())
    

    3. 重命名

    import 模块 as 模块新的名字 
    from 模块 import 变量名1 as 新的名字, 变量名2 as 新的名字 ……
    """
    er_tese = "name"
    # import ey_module as aa
    # print(aa.ey_test)
    
    # from ey_module import ey_test as a
    # print(er_tese)      # 使用当前模块的 ey_test
    # print(a)        # 使用ey_module中的 ey_test
    

    import: 可以检查被导入的内容之前是否已经导入过,如果导入过,不会再重复导入
    导入多次,但是只执行一次。多种导入只执行一次

    3. 选择性导入

    1. 阻止导入的方法

    if __name__ == "__main__":
        代码块 
    

    说明:
    if name =="main": ---> 固定写法
    代码块 ---> 在当前模块直接执行,代码块会被执行,如果被别的模块导入,这个代码块不会执行

    2. 每一个模块都有一个name属性,这个属性的默认值是当前模块对应的py文件的文件名

    当当前模块正在被直接执行的时候,系统会自动将模块的name属性变成main

    3. 什么时候使用模块

    将具有相似或相同的功能的函数和数据封装到一起

    函数时将多个代码块封装
    模块是将多个函数数据封装到一起

    4. 迭代器

    1. 什么是迭代器(iter)

    迭代器是python中的一种容器类的数据类型,属于序列,没有具体的字面量,可以将其他的序列转换为迭代器

    iter(序列)

    2. 迭代器的特点

    只能通过next()或者 迭代器.next() 方法去一个一个按顺序的获取迭代器中的元素,而且一旦元素被取出,迭代器中就不存在这个元素

    iter1 = iter("abcd")
    print(iter1)
    print(next(iter1))
    print(next(iter1))
    print(next(iter1))
    print(next(iter1))
    # print(next(iter1))        报错:StopIteration
    

    3. 遍历迭代器:

    iter2 = iter("abcde")
    
    print("=====")
    for x in iter2:
        print(x)
    print("+++++")
    # print(next(iter2))   # 取不到元素 因为上面已经取完
    
    
    iter3 = iter("abcd")
    print(iter3.__next__())
    print(next(iter3))
    

    生成器和生成式

    1. 什么是生成器

    生成器就是迭代器,但是迭代器不一定是生成器

    生成式就是生成器的一种特俗形式: (变量 for 变量 in 序列)
    特点:
    需要数据的时候根据算法去一次生成一个数据

    # 产生一个生成器,生成器中可以生成的数据是数字0~4 (每个元素是数字)
    generator1 = (x for x in range(5))
    print(generator1)
    
    print(next(generator1))
    print(next(generator1))
    print("===========")
    for item in generator1:
        print(item)
    
    
    print("++++++++++++")
    generator2 = (x*2 for x in range(5))
    for item2 in generator2:
        print(item2)
    
    
    generator3 = ([y, y*2] for y in "abc")
    print(next(generator3))
    
    
    print("========")
    generator4 = (x for x in range(5) if x%2)
    for item4 in generator4:
        print(item4)
    

    2. 生成器就是函数体中有yield关键字的函数 ---> 函数中只要有yield,那么调用函数不再是执行函数体

    获取返回值,而是产生一个生成器

    通过next获取生成器的元素的时候,会去执行生成器对应的函数的函数体,执行到yield位置,并且将yield
    后面的值产生(生成),然后保存当前结束的位置。下一次获取生成器元素的时候会接着上次结束的位置往后执行

    生成器可以当做序列来使用

    print("**********************")
    
    
    def function1(n):
        print("你好生成器")
        for x in range(n+1):
            print(x)
            yield x     # 生成x的值,调用next函数的时候取出来
    
    
    g4 = function1(10)
    print(g4)
    print("=:", next(g4))       # 你好生成器  0  =: 0
    print("=:", next(g4), type(g4))       # 1  =: 1
    

    文件的读和写

    文件用来干嘛?
    使用本地文件可以做数据的持久化(本地化) ---> 常用二进制文件 数据库文件 txt文件 json文件 plist文件

    1. 文件操作 --> 读写操作(二进制不能设置编码方式,编码方式是对应文本来讲的)

    读 ---> 取出文件中的数据
    写 ---> 将数据写到文件中

    所有文件操作基本过程: 先要打开文件 --> 操作文件 --> 关闭文件

    2. 打开文件和关闭文件

    • 打开文件: open(file, mode="r", encoding=None)

    a. file: 文件路径(必须传参),决定需要打开的是哪个文件
    绝对路径(不推荐): 完整文件路径
    相对路径:

    ./相对路径 (相对路径是相对当前py文件对应的文件夹)
    ../ ---> 当前文件夹上层文件夹
    .../ ---> 当前文件夹上层文件夹的上层文件夹
    

    b. mode: 决定文件打开方式(决定打开文件后是读还是写还是改……,不同操作对应不同打开方式)
    "r" --> read 以只读的形式打开,读文本文件
    "rb" / "br" --> 读操作,读出来的数据是二进制形式的数据
    "w" --> write 以写的方式打开文件
    "wb" / "bw" --> 写操作,将二进制数据写入文件
    "a" --> 写操作,追加

    c. encoding: 文本文件的编码方式
    utf-8: 几乎支持所有的语言文字
    gbk: 只支持英文

    d. open()函数的返回值,就是被打开的文件对象

    • 关闭文件: 文件对象.close()
    # # 在此文件绝对路径打开test.txt文件
    # a = open(r"D:\Study\phase 1\Day11_文件操作\test.txt")
    
    # # 在此文件相对路径打开test.txt, 文件操作.txt, 文件操作2.py文件
    # b = open("./test.txt")
    # c = open("./files/文件操作.txt")
    # d = open("./files/files2/文件操作2.py")
    #
    # # 在文件操作2中,相对路径打开test.txt, 文件操作.txt
    # e = open("../文件操作.txt")
    # f = open(".../test.txt")
    

    读文件

    # 1. 打开文件
    f1 = open("./test.txt", mode="r", encoding="utf-8")
    
    # 2. 读文件中的内容(每次读是按照上次读到的位置往下面读)
    """
    文件对象.read() ---> 从文件开始读到文件结束,返回读到的结果
    文件对象.readline() ---> 读一行
    文件对象.readlines() ---> 一行一行读完,每一行作为列表元素,返回列表
    """
    content2 = f1.read()
    print("=: ", content2)
    # content = f1.readline()
    # print(type(content), content, sep="\n")
    
    
    # 关闭文件
    f1.close()
    

    写文件一般先把原来的内容读出来,然后再写文件的时候用原来的内容加上添加的内容
    一般不用"a"去写文件,因为一般开发文件为json文件,使用"a"可能会导致文件被破坏
    "w" ---> 将字符串写入文件中,完全覆盖文件原来的内容
    "wb" / "bw" ---> 将二进制写入文件中,完全覆盖文件原来的内容
    "a" ---> 在文件的最后面去写内容

    # 1. 打开文件
    f2 = open("./test.txt", mode="w", encoding="utf-8")
    
    # 2. 写入文件
    f2.write(content2 + "我是被写入的hello python\n")
    # f2.writelines(["hahah, ", "我也被写进来了\n"])
    
    # 3. 关闭文件
    f2.close()
    

    相关文章

      网友评论

          本文标题:2018-10-14 Day 11 文件操作

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