day7_7.5 字符表与文件操作
一、字符编码。
1.
在计算机的运行中,有三大部分组成,计算机硬件,操作系统,应用程序,当使用者在使用文档编写文字时,所显示的所有字符都存储在内存中,随后再存储在硬盘里,(仅限文字),所以,当美国人发明电脑时,都是基于自己国家的文字编写的程序,所以,美国人发明了属于自己国家的字符表,也就是ASCLL码,,因为英文字母很少,加上一些特殊符号,阿拉伯数字等,ASCLL只有125位左右。一个字符码也就8bit。下面是数据的换算。
8bit=1Bytes
1024Bytes=1KB
1024KB=1MB
1024MB=1GB
1024GB=1TB
1024TB=1PB
然而,美国人发明的电脑只能输入英文,中国的字是显示不出来的,于是,中国人需要自己写一个表让电脑看懂中国,于是GBK出现了,GBK最多有2**16=65535个字符,每一个字符站2B。
既然中国人可以,那日本人,韩国人等都可以有,于是所有的国家根据自己的语言,编写了属于自己国家的字符码。
当每个国家都想着有能识别自己国家的码时,万国码出现了(unicode),万国码几乎容纳了所有语言的编译与翻译,它同一使用2个Byte表示。
至此为止,所有的表,在内存与硬盘中所都是一样的,然而万国码对cpu有这巨大的负担,原本1B的字符现在需要2B才能被存储,使用起来也相当麻烦。
所有,人们想出了一个方法,在内存中使用unicode,而再存储的时候使用另一个编码——utf-8,unicode向utf-8转换时,会将英文字符变成一个B,而将中文字符变成3个B。
总结。
unicode两个特点.
1。兼容万国字符
2。与每一个国家的编码都有对应关系,
从内存中的unicode二进制数据到硬盘中的utf-8的二进制数据称为编码(encode)
从硬盘中的utf-8二进制数据到内存中unicode二进制数据被称为解码(decode)
保证不乱码的核心点是:文本文件以什么类型的编码,就用什么类型的解码(*************)
2.python2与python3的区别
在python2 的编写是,unicode还没有盛行,所有python都已ASCLL进行编码,
而在python3中,都使用utf-8进行编码。
3.头文件定义字符的保存格式
在文件的开头,可以使用以下代码定义文件的保存格式
#coding:代码格式
因为所有编码格式都支持英文字符,所以无论什么表都可以识别该代码。
在python3中字符串默认是unicode,而在pycharm软件中,字符串默认为utf-8类型,在window终端编写程序时,使用的时GBK进行编码。
在python3的终端中,字符串经过编码后所表现的时bytes类型的数据.
在python2中定义中文字符串时,都会在前面添加‘u,吧字符串格式转换成Unicode’。
(**********)
x="上"
print(x.encode('utf-8'))
#将字符串转换成utf-8的二进制类型
print(res.decode('utf-8'))
#将硬盘中的utf-8二进制数解码成unicode格式的二进制。
二。文件
1.什么是文件
操作系统是提供给用户操作复杂硬件的简易接口。
2.为什么要操作文件
人或者应用程序需要永久保存数据。
3.如何操作文件
通过python代码操作文件。
在python中,可以通过open来定义一个变量f,,后对文件进行操作,语法如下:
f=open('D:\Python项目\day07\a.txt',encoding='utf-8')
其打印f后的结果是
<_io.TextIOWrapper name='D:\\python日常学习资料\\7_5day07\\代码\\day07\\a.txt' mode='r' encoding='utf-8'>
可以看到是一个接口,所以f所获得的是对计算机硬件接口的操作。
在定义文件名时,很容易出现\t这种转义字符很容易出现文件读取错误,所以,在输入文件地址时通常会在字符前加r,意思就是取消转译。
f = open(r'D:\python日常学习资料\7_5day07\代码\day07\a.txt',encoding='utf-8')
然而,window系统的默认读取文件的方式是gbk,在读取utf-8模式的字符串时,会报错,所以可以使用encoding参数指定文件读取的方式。
文件使用结束后可以使用f.close(),函数,将文件操作关闭,但是在使用这种方法关闭后,后续如果再想对文件进行操作,会报错误,即io口操作错误,所以python有一个方便简洁的造作文件的方法,语法如下
with open(r'D:\python日常学习资料\7_5day07\代码\day07\a.txt',encoding='utf-8') as f ,\
open(r'D:\python日常学习资料\7_5day07\代码\day07\b.txt',encoding='utf-8') as f1: # f仅仅是一个变量名 你把它看成是一个遥控器
print(f)
print(f1)
也可以通过这种方法将多个文件介入操作。
4.文件的处理模式
文件有三种对文件的操作模式:
r,只读模式
w,只写模式
a,追加模式
文件有两种对文件单位的方式
t,文本文件 以文本文件的形式操作文件
b,二进制 以二进制的方式操作文件,注意再这个模式下encoding不可以指定参数。
【r】其中mode指定的就是文件处理的模式R,W,A等,如果不指定,默认使用r只读模式,他,b不指定,默认指定t。
with open(r'D:\python日常学习资料\7_5day07\代码\day07\a.txt',mode='rt',encoding='utf-8') as f:
print(f.readable()) # 是否可读
print(f.writable()) # 是否可写
print(f.read()) # 一次性将文件内容全部读出
readable()输出的是文件是否可读,writable输出的是文件是否可写。read()可以将文件一次性读出,这种方式在读大型文件时,非常损耗进程,所以可以采用如下方式操作文件
print(f.readlines())
这中方式可以一行一行的读出文件,非常适合文件的操作。
【w】
只写模式切记要慎用,因为它在写文件时会将原来文件全部删除,再添加新的内容。
with open(r'xxx.txt',mode='w',encoding='utf-8') as f:
print(f.readable()) # 是否可读
print(f.writable()) # 是否可写
f.write('不不不,你没有翻~\n')
当文件xxx不存在时,会再该文件夹添加一个名为xxx的文件。
只写模式也有多行操作,其使用列表进行操作,将列表的每个元素作为一行进行写入。使用writelines()
with open(r'xxx.txt',mode='w',encoding='utf-8') as f:
l = ['不sdffs,sdfs有翻~\n','不sdfsdf不,你sdfsf翻~\n','不sfad不,你没sa翻~\n']
f.writelines(l)
【a】只追加模式
在a模式中,可以在文件末尾添加内容,如果文件夹没有该文件,则会添加该文件后追加内容。
with open(r'yyy.txt',mode='a',encoding='utf-8') as f:
print(f.readable()) # 是否可读
print(f.writable()) # 是否可写
f.write('我是小尾巴\n')
当有该文件时,会将光标移到文件末尾。不清空原来的文件内容。
【t】对文本文件的操作
在t模式下,操作出的数据是字符串。
with open('text1','rt',encoding='utf-8') as f:
print(type(f.read(3)))
#输出结果>>><class 'str'>
需要对其进行字符串类型定义,一般使用utf-8,在写入数据时也需要使用文本类型。
with open('text1','wt',encoding='utf-8') as f:
f.write('我我我我我我')
#输出结果>>>我我我我我我
【b】二进制模式
在这个模式下,encoding的值不需要被定义,而且读取文件时是以二进制的类型进行操作
with open('text1','rb') as f:
print(f.read())
print(type(f.read()))
#输出结果>>>b'\xe6\x88\x91\xe6\x88\x91\xe6\x88\x91\xe6\x88\x91\xe6\x88\x91\xe6\x88\x91'
#<class 'bytes'>
在写入数据时也是按照二进制写如,如果写入字符串类型会报错。
with open('text1','wb') as f:
f.write('我我我')
#输出结果>>>报错
所以,这里可以通过两种方法进行转换,1,使用encode()函数进行编码,将输入内容 编成二进制
with open('text1','wb') as f:
f.write('我我我'.encode())
#输出结果>>>我我我
2,使用bytes直接将字符串编码
with open('text1','wb') as f:
res='我我我'
f.write(bytes(res,encoding='utf-8'))
#输出结果>>>我我我
在读取文件时也可以通过解码和转换字符串的方式
with open('text1','rb') as f:
res=f.readline()
print(str(res,encoding='utf-8'))
res2=f.readline()
print((res2.decode('utf-8')))
#输出结果>>>我我我wwwada
#
#你你你
# coding:gbk
day7_7.5 字符表与文件操作的更多相关文章
- Python 字符编码及其文件操作
本章节内容导航: 1.字符编码:人识别的语言与机器机器识别的语言转化的媒介. 2.字符与字节:字符占多少个字节,字符串转化 3.文件操作:操作硬盘中的一块区域:读写操作 注:浅拷贝与深拷贝 用法: d ...
- DAY7 字符编码和文件操作
一.软件与python解释器打开文件的方法 1.软件打开文件读取数据的流程: 1. 打开软件 2. 往计算机发生一个打开文件的指令,来打开文件 3. 读取数据渲染给用户(存取编码不一致:乱码) 2.p ...
- Day 07 字符编码,文件操作
今日内容 1.字符编码:人识别的语言与机器识别的语言转换的媒介 2.字符与字节:字符占多少字节,字符串转换 3.文件操作:操作硬盘的一块区域 字符编码 重点:什么是字符编码 人类能识别的字符等高级标识 ...
- day7 七、字符编码,字符字节与文件操作
一.字符编码 1.定义:人类能识别的是字符等高级标识符,电脑只能识别0,1组成的标识符,要完成人与机器之间的信息交流,一定需要一个媒介,进行两种标识符的转化(两种标识符的对应关系) 对应关系形成的结构 ...
- Python 入门基础6 --字符编码、文件操作1
今日内容: 1.字符编码 2.字符与字节 3.文件操作 一.字符编码 了解: cpu:将数据渲染给用户 内存:临时存放数据,断电消失 硬盘:永久存放数据,断电后不消失 1.1 什么是编码? 人类能够识 ...
- Python基础之字符编码,文件操作流与函数
一.字符编码 1.字符编码的发展史 阶段一:现代计算机起源于美国,最早诞生也是基于英文考虑的ASCII ASCII:一个Bytes代表一个字符(英文字符/键盘上的所有其他字符),1Bytes=8bit ...
- python基础——6(字符编码,文件操作)
今日内容: 1.字符编码: 人识别的语言与机器识别的语言转化的媒介 ***** 2.字符与字节: 字符占多少字节,字符串转化 *** 3.文件操作: 操作硬盘中的一块区域:读写操作 ...
- python学习道路(day3note)(元组,字典 ,集合,字符编码,文件操作)
1.元组()元组跟列表一样,但是不能增删改,能查.元组又叫只读列表2个方法 一个 count 一个 index2.字典{}字典是通过key来寻找value因为这里功能比较多,所以写入了一个Code里面 ...
- Python-字典、集合、字符编码、文件操作整理-Day3
1.字典 1.1.为什么有字典: 有个需求,存所有人的信息 这时候列表就不能轻易的表示完全names = ['stone','liang'] 1.2.元组: 定义符号()t = (1,2,3)tupl ...
随机推荐
- Springboot项目启动不了。也不打印任何日志信息。
Springboot项目启动不了.也不打印任何日志信息. <!-- 在创建Spring Boot工程时,我们引入了spring-boot-starter,其中包含了spring-boot-sta ...
- git相关2
初学备忘: git安装好后,目录右键 => Git Bash here _________________________ 初始化仓库 git init 仓库名 配置仓库 git config ...
- BoW算法及DBoW2库简介
由于在ORB-SLAM2中扩展图像识别模块,因此总结一下BoW算法,并对DBoW2库做简单介绍. 1. BoW算法 BoW算法即Bag of Words模型,是图像检索领域最常用的方法,也是基于内容的 ...
- Orm框架(AntOrm,Ktorm)在mac机器上如何使用代码生成
Orm框架介绍 AntOrm 是我维护的一个开源csharp -netcore 项目 Ktorm 是一个大神开源的kotlin项目 由于我工作上都用到了,为了提高工作效率 我写了一个mac端工具帮助快 ...
- pymysql 读取大数据内存卡死的解决方案
背景:目前表中只有5G(后期持续增长),但是其中一个字段(以下称为detail字段)存了2M(不一定2M,部分为0,平均下来就是2M),字段中存的是一个数组,数组中存N个json数据.这个字段如下: ...
- background属性怎么添加2个或多个背景图
最近遇到一个需求,下面充值金额按钮是一个背景图,点击之后显示的状态也是一个背景图,如下图 按照惯用的套路,新增一个class,点击后的状态直接写在里面即可 然而点击后,虽然状态背景成功显示出 ...
- Redis缓存穿透,缓存击穿,缓存雪崩,热点Key
导读 使用Redis难免会遇到Redis缓存穿透,缓存击穿,缓存雪崩,热点Key的问题.有些同学可能只是会用Redis来存取,基本都是用项目里封装的工具类来操作.但是作为开发,我们使用Redis时可能 ...
- MySQL for OPS 06:备份恢复
写在前面的话 人在河边走,湿鞋是早晚是事情,操作服务器,数据库也一样.谁也不知道自己哪一天控制不住自己就手贱.这时候有两个东西能救我们,一是备份,二是 bin log,bin log 前面讲了,但是 ...
- Zabbix邮件预警-这个坑我跳了不止一次
文章 Github 地址:点我 每每碰到 Zabbix,我发现配置邮件预警这个坑,我必须要跳进去,跟它是有八辈子的仇哦,哎,接下来数数这些坑.看看你遇到过类似的吗? Zabbix 预警配置流程 监控项 ...
- background 设置文本框背景图
background 属性的作用是给元素设置背景,它是一个复合属性,常用的子属性如下: background-color 指定元素的背景颜色. background-image 指定元素的背景图像. ...