栏目分类:
子分类:
返回
文库吧用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
文库吧 > IT > 软件开发 > 后端开发 > Python

day11

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

day11

数据持久化:
  • 将数据从顺时状态转换为持久状态
Python操作文件: 操作文本文件:
  • 新建(重命名) -> 打开 -> 写数据 -> 保存关闭
  • 打开 -> 读数据 -> 关闭
表格文件(excel):
  • 新建 -> 打开 -> 写数据 -> 保存、关闭、重命名
  • 打开 -> 读数据 -> 关闭
文件操作形式:
  • 以什么形式操作文件
  • 以什么数据类型操作文件
以什么形式操作文件:读、写:
  • r:只读,文件不存在,报错
  • w:只写,文件不存在先创建,如果存在,先清空
  • a:追加,不存在先创建,文件存在继续添加内容
以什么数据类型操作文件:
  • t: 字符串形式(如果选t可以不写,默认的,选r就相当于是 rt/tr)
  • b:二进制形式:一般计算机中存储的数据都是以二进制形式存在的(图片、音频、视频等)
文件读写操作 open(参数1,参数2,参数3,参数4):
  • 参数1:文件路径、文件名
  • 参数2:文件操作模式
  • 参数3:编码方式,encoding = ‘utf-8’
  • 参数4:换行方式,newline = ‘’(读操作也可以不指定该参数)
补充:
  • r 是将鼠标光标移动到下一行行首。
  • 文件路径分为:相对路径、绝对路径
  • 绝对路径:一个文件存放在哪个磁盘下的什么文件夹
  • 相对路径:以当前文件为参照物,另一个文件相对于它的位置
  • .表示当前目录
  • …表示返回上级
# 以文件对象的形式打开文件
file = open(r'test.txt', 'r', encoding='utf-8', newline='')
# print(file)
# 读操作:
# read:一次性将文件中的内容以字符串的形式全部提取出来
# readline:只读取一行
# readlines:一行一行读取,将每一行放在列表中
# result = file.read()
# print(result)
result1 = file.readline()
result10 = file.readline()
result11 = file.readline()
result2 = file.readlines()
print(result1, result10, result11)
print(result2)
# 关闭文件
file.close()
写操作:
file = open('古诗.txt', 'w', encoding='utf-8', newline='')
# write:向文件写入内容
str1 = '静夜思n唐 李白n床前明月光n疑是地上霜n'
file.write(str1)
file.close()

# 追加
file = open('古诗.txt', 'a', encoding='utf-8', newline='')
# write:向文件写入内容
str1 = '举头望明月n低头思故乡'
file.write(str1)
file.close()

# 读文件
file = open('古诗.txt', 'r', encoding='utf-8')
# write:向文件写入内容
str1 = '举头望明月n低头思故乡'
print(file.read())
file.close()
# file.read()  # ValueError: I/O operation on closed file.

# I/O ----> Input/Out  输入/输出
with的用法: 预定义的清理操作
  • 只要退出了with的缩进,直接进行清理操作,将文件关掉。
eval的用法:
  • 将字符串序列化(里面必须写长度非0的字符串):将字符串中的数据转换为它最原本的数据类型,例如: ‘[1,3,5,6]’ 转换为之后就是[1,3,5,6]
with open('eval测试.txt', 'w', encoding='utf-8', newline='') as file:
    file.write('1n')
    list1 = [1, 2, 3, 4, 5]
    file.write(f'{list1}')

with open('eval测试.txt', 'r', encoding='utf-8') as file:
    result = file.readline()
    print(result, type(result))
    print(file.readline())

# eval:将字符串序列化(里面必须写长度非0的字符串):将字符串中的数据转换为它最原本的数据类型,例如:
# '[1,3,5,6]' 转换为之后就是[1,3,5,6]
print(eval('1') + 2)
print('[1,2,3,45,5]'[0])
print(eval('[1,2,3,45,5]')[0])
print(eval('abcd'))
读写视频、图片: rb、rw
file = open('Y{](N))([GUFR~U[ZZ$J@8F.jpg', 'rb')
result = file.read()
file.close()

print(result)
# b'xxxxxx' 二进制字节码

# 将图片二进制数据写进去
file = open('phone2.jpg', 'wb')
file.write(result)
file.close()

with open('MarkDown为什么会这么流行.mp4', 'rb') as file:
    result = file.read()
    print(result)

with open('MarkDown.mp4', 'wb') as file1:
    file1.write(result)
csv文件操作:
  • CSV文件中的数据是以表格形式展示,但是其中的原理是文本文件的原理。
  • writerow() - 单行写入,writerow中传递一个列表,列表表示一行,列表中的一个元素代表一个单元格的内容
  • writerows() - 多行写入,传入一个列表,列表中有几个元素代表写几行, 其中的每个元素代表一个单元格的内容
import csv

csvfile = open('学生成绩.csv', 'w', encoding='utf-8', newline='')
# 先写列
# 使用CSV = 模块提供的writer方法进行文件写操作

myWrite = csv.writer(csvfile)

# writerow() - 单行写入,writerow中传递一个列表,
# 列表表示一行,列表中的一个元素代表一个单元格的内容
myWrite.writerow(['编号', '姓名', '年龄', '专业'])

# writerows() - 多行写入,传入一个列表,列表中有几个元素代表写几行,
# 其中的每个元素代表一个单元格的内容
myWrite.writerows([
    ['python001', '张三', '18', '网络工程'],
    ['python001', '张三', '18', '网络工程'],
    ['python001', '张三', '18', '网络工程']
])

csvfile.close()

# --------------------------------------------------------------------
file = open('学生成绩.csv', 'r', encoding='utf-8')

# csv.reader得到一个可迭代对象
date = csv.reader(file)
for i in date:
    print(i)

file.close()
----------
file = open('学生成绩.csv', 'r', encoding='utf-8')

# csv.reader得到一个可迭代对象
date = csv.reader(file)
for i in date:
    print(i)

file.close()
转载请注明:文章转载自 www.wk8.com.cn
本文地址:https://www.wk8.com.cn/it/1038017.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 wk8.com.cn

ICP备案号:晋ICP备2021003244-6号