Day11文件操作

模块的使用

1、导入模块

"""
python中一个.py文件就是一个模块
可以通过import或者from import 在一个模块中去使用另一个模块的内容

代码执行到import的时候,会将import后面的内容执行一遍

import 模块名--->将模块所有内容导入,并在当前模块中通过'模块名.'的方式使用模块中所有的全局变量

from 模块1 import 变量1,变量2,…… --->将模块中所有的内容都导入,只能使用import的变量

from 模块1 import 变量1,变量2,…… --->将模块中所有的内容都导入,所有变量都可以直接使用
"""
import test1

2、重命名

'''
给模块重命名:import 模块名 as 新模块名
使用模块需用新的名字使用

给引用模块的变量重命名:from 模块1 import 变量1 as 新变量名
'''

3、import

'''
可以检查被导入的内容以前是否已经导入过,如果导入过,不会再重新导入
导入多次只执行一次,多种导入的效果可以同时生效

选择性导入(阻止导入)

1、
if name == 'main':
代码块
在导入模块的时候,不希望被导入的模块写在这
if name == 'main':--->固定写法
直接执行当前代码块,代码块会被执行,被其他模块导入,则不会执行

2、Python每一个模块都有name属性,这个属性的默认值是当前py文件的文件名
当当前模块默认被执行的时候,系统会自动将模块的name属性编程main

3、什么时候使用模块:
将具有相同功能的函数和数据封装到一起,就可以使用模块

迭代器

1、什么是迭代器(iter)
迭代器是Python中一种容器类数据类型,属于序列,没有具体的字面量,可以将其他的序列转换成迭代器
iter(序列)

2、迭代器的特点:
只能通过next方法去一个一个按顺序获取迭代器中的元素,取出后迭代器中就不存在这个元素了

iter1 = iter('abcde')
print(iter1)
print(next(iter1))
print(next(iter1))

3、遍历迭代器

next(迭代器)
迭代器.next

生成器

生成器就是迭代器,迭代器不一定是生成器
生成式就是生成器的一种特殊形式
generator
产生一个生成器,生成器可以产生的数据是数字0-9
ge1 = (x for x in range(10))
print(ge1)
print(next(ge1))
print(next(ge1))
print('~~~~~~~~~~')
for item in ge1:
print(item)

ge2 = (x*2 for x in range(7))
print(ge2)
print(next(ge2))
print(next(ge2))
print('~~~~~~~~~~')
for item in ge2:
print(item)

ge3 = ([x,x*2] for x in 'abcde')
print(ge3)
print(next(ge3))
print(next(ge3))
print('~~~~~~~~~~')
for item in ge3:
print(item)

2、生成器就是函数体中已有yield关键字的函数
-->函数中只要有yield关键字,那么调用这个函数就不再执行函数体,而是产生一个生成器

通过next获取生成器元素的时候,回去执行生成器对应的函数的函数体,执行到yield后面的值获取返回值,
然后保存当前结束的位置,下一次获取生成元素的时候,会接着上次结束的位置往后执行到yield
生成器可以当成序列来使用

文件的读和写

使用本地文件可以做数据的持久化--->数据库文件,txt文件,json文件,plist文件,二进制文件

1、文件操作--读写操作
读-->取出文件的数据
取-->将数据写到文件中

所有文件操作过程都是一样的:打开文件,操作文件,关闭文件
2、打开文件
open(file,mode= 'r',)
a.file:必传,文件路径,决定你需要打开的是那个文件
写法:
绝对路径:(不推荐使用)
相对路径:./相对路径(相对当前.py文件对应的文件夹)
./--->当前文件夹
../--->当前文件夹的上层文件夹
.../--->当前文件夹的上层文件夹的上层文件夹

b.mode:文件打开方式,不同的操作对应不同的打开方式
'r'-->以只读的形式打开文件,文本文件
'rb'/'br'-->读操作,以二进制的方式读取文件
'w'-->以写的方式打开文件
'bw'/'wb'-->写操作,将二进制数据写入文件
'a'-->写操作,追加

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

d.open对象的返回值,就是被打开的对象

关闭文件:
文件对象.close()

1、打开文件

f1 = open('./txt')

2、读取文件的内容

content = f1.read()
print(type(content),content)
'''文件对象.read(),从文件开始读到文件结束,返回读到的结果
文件对象.readline(),读一行
文件对象.readlines(),返回一个列表,列表的内容是文件中每一行的内容

3、关闭文件
f1.close()

-------------------文件的写操作------------------------------

1、打开文件
open('./txt','w')

'w'-->将字符串写入文件中,完全覆盖原来的文件内容
'wb'和'bw'-->将二进制内容写入文件,完全覆盖原来的文件内容

3、写入文件
f2 = write(content+'hello world!')

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、recode 1.匿名函数 函数名 = lambda 参数列表:返回值参数列表: 变量名1,变量名2 函数体是...
    大漠判官1阅读 1,787评论 0 0
  • 一回顾 """ 1.匿名函数 函数名 = lambda 参数列表:返回值参数列表: 变量名1,变量名2 函数体是一...
    龙神海王阅读 1,391评论 0 0
  • 1.recode 1.匿名函数 函数名= lambda 参数列表:返回值匿名函数也是函数。func1 = lamb...
    逆流而上_2eb6阅读 1,150评论 0 0
  • 1.模块的使用 1.什么是模块:python中一个py文件就是一个模块。可以通过import或者from-impo...
    PythonLi阅读 1,670评论 0 0
  • 今天在公司忙着整理游学班的物资,现在开课越来越简单了!东西也越来越少了!这次游学班和以前有了很大的调整,少数几个参...
    何德胜觉悟阅读 1,254评论 0 1