day11-文件操作

2018-11-19  本文已影响0人  L_4bc8

0. record

1.容器类数据类型:
列表: 可变,有序
元组: 不可变,有序 x, y =12, 100; x, *num = 12, 33, 45, 23
字典: 可变 无序
集合: 可变,无序: 元素唯一:支持数学集合运算.

  1. 函数
    a. 函数的声明
    def 函数名(参数列表:)
    函数体

b. 函数的调用
回到函数声明的位置
传参数(使用实参给形参赋值)
执行函数体
确定返回值
回到函数调用的位置.

c. 参数
位置参数,关键字参数
不定长参数:带的优先放后面,不能放没有的前面

d.确定一个函数的返回值
函数调用函数表达式, 就是函数的返回值.
函数调用的表达式 - 就是函数的返回值,
调用函数:1.) 会执行函数体. 2)获取返回值

d. 匿名函数
lambda 参数列表:返回值.

d. 全局变量和局部变量

e.迭代器
a. 迭代器: 容器, 可以同时存储多个数据,取的时候只能一个一个取, 并且取过的数据在容器中就不存在.

b. 生成器: 是迭代器.数据是通过调用函数,获取yeild后面的值而产生的..数据会在获取的时候产生.
调用一个yield关键字的函数,就是创建一个生成器.

1.生成式

格式1:
(表达式 for 变量 in 序列 )
展开:

def func():
  for变量 in 序列
      yeild表达式

格式2:
(表达式 for 变量 in 序列 if(条件语句)
展开:

def func1():
  for 变量 in 序列:
    if 条件语句:
      yeild 表达式

2. 模块的使用

2.1. 什么是模块

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

2.2怎么关联多个模块

方式1:
import 模块名 - 将指定的模块中所有的变量导入到当前模块中(模块名就是py文件的文件名)

说明:
a. 执行import的时候, 实质会进入指定的模块对应的py文件中,取执行里面的 代码.
b. 通过import去导入一个模块的时候,会检测当前模块是否导入过,如果已经导入就不再导入,
c. 然后,可以通过 模块名.全局变量 去使用被导入的模块中的内容.

import test1

方式2:
from 模块名 import 变量名/整数名 - 导入模块中指定的变量

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


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

3. 重命名]mport 模块名 as 新模块名

from 模块名 import 变量名 as 新变量名

4. 包的导入

import.包名 -会直接执行包中init.py文件中的代码
import 包名.模块名 - 导入指定包中的执行模块.
from 包名 import 模块名
from 包名.模块名 import 变量
5.选择性导入
在模建不需要其它
`

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

5文件 录入:

5.1. 数据本地化

将数据中保存的数据都是存到内存中的,当程序运行结束时运内存中行会被销毁

5.2.文件操作(读和写)

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

5.3打开文件

open(file, mode='r',..., encoding=None)
说明:
file - 字符串; 需要打开的文件的路径(可以是绝对路径, 也可以是相对路径)
(一般不使用))绝对路径:
相对路径:(相对当前的py对应的目录):
./ 当前目录(./可以省略) aaa.txt ./aaa.txt
../ 当前列表的上层目录.
.../ 当前目录的上上层目录.

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

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

f = open('files/蓝莲花.txt', 'r', encoding='utf-8')

5.4. 文件的读操作.

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

f = open('files/蓝莲花.txt', 'r', encoding='utf-8')
content = f.readline()
while content:
    print(content)
    content = f.readline()
f.close()

5.5 文件的写操作

文件对象.write(字符串) - 将字符串中的内容写入到文件中.
'w' 完全覆盖
'a'在末尾添加

f = open('files/蓝莲花.txt', 'a', encoding='utf-8')
f.write('你好吗?')

5.6 关闭文件

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

f.close()

1.open的另外一种写法:

with open(文件路径,读写方式,encoding=编码方式) as 文件对象:
\ 文件操作

with open ('files/蓝莲花.txt', encoding='utf-8') as f:
    print(f.read())
print(f.closed)     # True

2.二进制文件的读写

只要将读写方式设置为'rb'/'br'就可以了,读出来的数据直接就是二进制数据.
注意:二进制操作不能设置编码方式.

with open('files/蓝莲花.txt', 'rb') as f:
    content = f.read()
    print(content, type(content))

with open('files/luffy4.jpg', 'rb') as f:
    content = f.read()
    print(content)

# 二进制文件的写
with open('imge.jpg', 'wb') as f:
    f.write(content)

3.文件不存在

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

# with open('bbb.txt', 'r') as f:
#     print(f.read())


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

7.文件操作的应用

写一个程序统计当前程序执行的次数。第一次运行程序打印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'方式打开,写入的时候只能写字符串
    f.write(str(count))
    f.write()
上一篇下一篇

猜你喜欢

热点阅读