2018-10-14 Day 11 文件操作

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 文件操作)