python基础 Day8
python Day8
文件操作的识
利用python代码写一个脚本操作文件的过程
文件的路径:path
打开方式:读,写,追加,读写,写读
编码方式:utf-8,gbk,gb2312
简单文件读取(文件存储时与文件打开时编码本运用必须一致)
f1=open("111.txt",encoding="utf-8",mode="r")
content=f1.read()
print(content)
f1.close()
#encoding不写的话默认操作系统方向的编码,通常window是gbk,mac和linux都是utf-8
#这里txt文件写入的编码格式是utf-8所以编码的格式需要写utf-8,如果是其他编码类型将会报错
- 文件操作的三部曲:
- 打开文件
- 对文件句柄进行相应的操作
- 关闭文件
- 文件操作的三部曲:
文件的操作读
读里面的"r"模式的使用
#文件读取的全读模式
f1=open("111.txt",encoding="utf-8",mode="r")
content=f1.read()
print(content)
##结果:详细内容请查看 www.tiebai.comcom
#文件读取的按字符模式
f1=open("111.txt",encoding="utf-8",mode="r")
content=f1.read(4)#里面的数字则是从第几个数字开始
print(content)
##结果:详细内容
#文件读取的按行读取
f1=open("111.txt",encoding="utf-8",mode="r")
content=f1.readline()#里面的数字则是从第几个数字开始
print(content)
##结果:详细内容
#文件读取的将所有行全部读取,并以列表的形式返回
f1=open("111.txt",encoding="utf-8",mode="r")
content=f1.readlines()#里面的数字则是从第几个数字开始
print(content)
##结果:['详细内容请查看\n', 'www.tiebai.com']
读里面的"rb"模式的使用(常用于视频,图片等非文本数据
image1=open("1595835526701.png",mode="rb")
image1=image1.read()
print(image1)
###结果 b'\x89PNG\r\n\x1a\n\x00\x00\x00\rIHDR\x00\x00\x039\x00\x00\x02\x90\x08\x06\x00\x00\x00\xbcv\xb4\x8b\x00\x00 \x00IDATx\x9c\xec\xbd\xe9r$I\x96\xa5\xf7\xe9f\x8b/\x00\x02\x11\x99Y5\xd5\xd5\xc3i\x99~\x14>\x0b\x1f\x85/\xc8\x9fM
文件的操作写的
写里面的"w"模式的使用
#写文件,如果文件不存在就会创建文件,进行写入,如果文件春在就会清空文件在进行写入。
image1=open("爱萝莉",mode="w")
print(image1.write("fdsf"))
f.close()
写里面的"wb"模式的使用
#文件操作的字节模式进行写入
image1=open("1595835526701.png",mode="rb")
content=image1.read()
imag2=open("照片.png",mode="wb")
imag2.write(content)
f.close()
文件操作的追加
文件追加里面的"a"的使用
#有文件,在原文件的最后面追加内容,没有文件创建文件追加内容
f1=open("文件追加",mode="a")
f1.write("DSdadasdd")
f1.close()
文件的其他操作模式
文件读写模式中的"r+"的使用
#先读后写,写入的位置与光标的位置有关
f=open("其他模式",encoding="utf-8",mode="r+")
content=f.read()
print(content)
f.write("fjsfdsg")
f.close()
打开文件的另一种方式
优点1:不用关闭文件的句柄
with open("其他模式",encoding="utf-8",mode="r") as f:
print(f.read())优点2:可以同时打开多个文件进行处理
#flush强制刷新
with open("dsf.txt",encoding="utf-8") as f,open("爱萝莉",encoding="utf-8") as f1:
print(f.read(),f1.read())
文件的修改步骤
- 以读的模式打开原文件
- 以写的模式创建一个新文件
- 将原文件的内容读出来修改成新内容,写入新文件
- 将原文件删除
- 将新文件重命名成原文件
import os
#将文件中zhuxiayu部分修改成fengchaoSB
##以读的形式打开原文件,以写的形式创建新文件
with open("自述.txt",encoding="utf-8") as f1,\
open("自述1.txt",encoding="utf-8",mode="w") as f2:
#将原文件的内容读取出来并进行修改,写入新文件
old_content=f1.read()
new_content=old_content.replace("zhuxiayu","fengchaoSB")
f2.write(new_content)
os.remove("自述.txt")
#对新文件进行重新命名
os.rename("自述1.txt","自述.txt")- 以循环的形式进行修改升级版本
import os
#将文件中zhuxiayu部分修改成fengchaoSB
##以读的形式打开原文件,以写的形式创建新文件
with open("自述.txt",encoding="utf-8") as f1,\
open("自述1.txt",encoding="utf-8",mode="w") as f2:
#以循环的模式以此写入
for line in f1:
new_content=line.replace("fengchaoSB","zhuxiayu")
f2.write(new_content)
os.remove("自述.txt")
#对新文件进行重新命名
os.rename("自述1.txt","自述.txt")
#使用这样方法关于写入清空的问题
#清空是关闭文件句柄,在次以w的形式打开此文件时候才会进行清空,所以上门一直通过循环进行写入是不会清空上一行的文件信息
作业
用户输入一个数字,判断一个数字是否为一个水仙花数,水仙花数是一个三位数,三位数的每一位三次方的和还等于这个数,那么这个数就是一个水仙花数
#eg:1^3+5^3+3^3=153
number=input("please input number:")
if number.isdecimal():
if len(number)==3:
x1=int(number[0])
x2=int(number[1])
x3=int(number[2])
if x1**3+x2**3+x3**3==int(number):
print("其为水仙花数")
else:
print("不是水仙花数")
else:
print("数字不正确")
else:
print("请输入三位数合法数字")将list=["周大苏打","周对手的防守","马虎他","周星星"]中首字母是周字的删除
list=["周大苏打","周对手的防守","马虎他","周星星"]
#这里有坑,因为在列表的删除过程中,删除一个元素其他会前移,会出现问题,所以采用倒叙删除
for i in range(len(list)-1,-1,-1):
if list[i][0]=="周":
list.pop(i)
print(list)车牌分块区分,现给出车牌,根据车牌的信息,分析的各省车牌持有量
cars=["鲁A2444","鲁B1233","京B8989M","黑C49678","黑C46555","沪B25041"]
locals={"沪":"上海","黑":"黑龙江","鲁":"山东","鄂":"湖北","湘":"湖南","京":"北京"}
#车牌分块区分,现给出车牌,根据车牌的信息,分析的各省车牌持有量
countlist={}
for i in cars:
if locals[i[0]] not in countlist:
countlist[locals[i[0]]]=1
else:
countlist[locals[i[0]]]=countlist[locals[i[0]]]+1
print(countlist)#升级版
countlist={}
for i in car:
countlist[locals[i[0]]]=countlist.get(locals[i[0]],0)+1
print(countlist)通过文件形式将txt格式的商品价格,商品数量,商品名字以列表嵌套字符串的形式表现
dic={}
list1=[]
with open ("a.txt",encoding="utf-8",mode="r") as f1:
for line in f1:
line=line.strip("\n").split(" ")
dic["name"]=line[0]
dic["price"] = line[1]
dic["count"] = line[2]
list1.append(dic)
print(list1)
python基础 Day8的更多相关文章
- Python基础Day8
一.内容回顾 列表的存储:列表里的元素存储的是值的内存地址,就算通过copy,复制后容器里的值也是指向同一个内存地址(跟驻留机制有关) l1 = [1,2,3, l2 = l1.copy() 浅cop ...
- python笔记 - day8
python笔记 - day8 参考: http://www.cnblogs.com/wupeiqi/p/4766801.html http://www.cnblogs.com/wupeiqi/art ...
- python之最强王者(2)——python基础语法
背景介绍:由于本人一直做java开发,也是从txt开始写hello,world,使用javac命令编译,一直到使用myeclipse,其中的道理和辛酸都懂(请容许我擦干眼角的泪水),所以对于pytho ...
- Python开发【第二篇】:Python基础知识
Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...
- Python小白的发展之路之Python基础(一)
Python基础部分1: 1.Python简介 2.Python 2 or 3,两者的主要区别 3.Python解释器 4.安装Python 5.第一个Python程序 Hello World 6.P ...
- Python之路3【第一篇】Python基础
本节内容 Python简介 Python安装 第一个Python程序 编程语言的分类 Python简介 1.Python的由来 python的创始人为吉多·范罗苏姆(Guido van Rossum) ...
- 进击的Python【第三章】:Python基础(三)
Python基础(三) 本章内容 集合的概念与操作 文件的操作 函数的特点与用法 参数与局部变量 return返回值的概念 递归的基本含义 函数式编程介绍 高阶函数的概念 一.集合的概念与操作 集合( ...
- 进击的Python【第二章】:Python基础(二)
Python基础(二) 本章内容 数据类型 数据运算 列表与元组的基本操作 字典的基本操作 字符编码与转码 模块初探 练习:购物车程序 一.数据类型 Python有五个标准的数据类型: Numbers ...
- Python之路【第一篇】python基础
一.python开发 1.开发: 1)高级语言:python .Java .PHP. C# Go ruby c++ ===>字节码 2)低级语言:c .汇编 2.语言之间的对比: 1)py ...
随机推荐
- ElasticSearch(一)概念介绍及环境搭建
一.什么是ElasticSearch: Elasticsearch (ES)是一个基于Lucene构建的开源.分布式.RESTful 接口全文搜索引擎.Elasticsearch 还是一个分布式文档数 ...
- sqlite文件的建立和as的应用,
建立目录D:\android_projects\qrscan\app\src\main\assets把数据库文件d:\sqlite_files\device.db 拷贝到 D:\android_pro ...
- pv绑定pvc
创建pvapiVersion: v1kind: PersistentVolumemetadata: name: pv003 labels: app: vnc003 namespace: vnc-spa ...
- 修改python默认版本
查看默认Python版本 python -V 1.安装gcc,用于编译Python源码 yum install gcc 2.下载源码包,https://www.python.org/ftp/pytho ...
- 【Django组件】WebSocket的简单实现
1:HTML: <!DOCTYPE html><html lang="en"><head> <meta charset="UTF ...
- Redis系列(九):Redis的事务机制
提到事务,相信大家都不陌生,事务的ACID四大特性,也是面试时经常问的,不过一般情况下,我们可能想到的是传统关系型数据库的事务,其实,Redis也是提供了事务机制的,本篇博客就来讲解下Redis的事务 ...
- JavaScript Symbol对象
JavaScript Symbol对象 Symbol Symbol对象是es6中新引进的一种数据类型,它的作用非常简单,就是用于防止属性名冲突而产生. Symbol的最大特点就是值是具有唯一性,这代表 ...
- 如何使用k3OS和Argo进行自动化边缘部署?
本文转自边缘计算k3s社区 前 言 随着Kubernetes生态系统的发展,新的技术正在被开发出来,以实现更广泛的应用和用例.边缘计算的发展推动了对其中一些技术的需求,以实现将Kubernetes部署 ...
- PHP array_udiff_uassoc() 函数
实例 比较两个数组的键名和键值(使用用户自定义函数进行比较),并返回差集: <?phpfunction myfunction_key($a,$b){if ($a===$b){return 0;} ...
- luogu P5410 模板 扩展 KMP Z函数 模板
LINK:P5410 模板 扩展 KMP Z 函数 画了10min学习了一下. 不算很难 思想就是利用前面的最长匹配来更新后面的东西. 复杂度是线性的 如果不要求线性可能直接上SA更舒服一点? 不管了 ...