day07----字符编码解码、文件操作(1)
字符编码:
- 什么是字符编码?
字符编码是将人识别的字符转换成计算机能识别的二进制字符(01),转换的规则就是编码表。
人能识别的字符串 与 计算机能识别的二进制字符 两者之间对应关系构成的结构称为:编码表
- ASCII码: 字母、数字、英文符号与计算机01标识符的对应关系
- 中国(研究汉字与01标识符之间关系):GB2312---->GBK----->GB18030
- 日本:shift_JIS
- 韩国:Euc-Kr
- 万国码(unicode): 目的是创造出一个可以完成各国字符与计算机的01标识符对应的编码表——————>UTF-8
- 注意:
- python2 中 使用的是 ASCII码,原因是在python2 诞生之前,没有万国码
- python3中使用的是UTF-8,采用万国编码来解释文本内容
- UTF-8 与unicode关系:
- unicode 是用两个字节存储汉字,也是用两个自己存储英文字符的,(长度不可变)占用空间较多,但是读取效率高。
- UTF-8是用三到六个字节存储汉字,用一个字节来存储英文字符的,(长度可变)占用空间较小,但是读取效率较低。
- unicode 与UTF-8都是采用一张编码表,UTF-8是 unicode的体现方式(变长传输,提高传输效率),由于多数数据都是以英文形式存在,所以UTF-8所占空间更小,传输速度更快。
- 乱码问题:本质上存数据与读取的数据采用的编码表不同。
- 理解文件传输过程中的字符编码的变化:
- 在硬盘中,文件可以以各种形式的编码来存储,在传输过程中,即在硬盘往内存中传输文件的过程中,文件都是以UTF-8编码形式传输的,读取到内存后,内存中存储数据是采用的是unicode,然后由内存读到cpu 过程中,也是UTF-8编码形式传输的,读到cup的文件的编码形式也就是UTF-8。
- 编码与解码:
s1 = u'abc你好\n不好' # 万国字符串
print(s1)
s2 = b'abc23\xb7\xb7' # 字节字符串
print(s2)
s3 = r'abc你好\n不好' # 原义字符串
print(s3)
# 编码与解码:
s = '123呵呵'
b = bytes(s, encoding='utf-8')
n_b = str(b, encoding='utf-8')
n_b1 = str(b, encoding='GBK')
print(b, n_b, n_b1) # 将u字符串编码成b字符串
print(u'你好'.encode('utf-8')) # 将b字符串解码成u 字符串
print(b'123\xe5\x91\xb5\xe5\x91\xb5'.decode('utf-8'))
文件操作:
计算机中的文件:本质上是硬盘上存储的一块空间的虚拟文件
文件操作:根据文件名来操作硬盘中的存储空间的虚拟文件,操作方式有:读(read)写(write)
操作文件的流程: 打开文件——————操作文件(读写)———————关闭文件
- 基本读写操作:
# 一使用文件的三步骤:
# 1.打开文件
# 变量名 = 文件空间
# 文件路径 操作模式(读|写) 编码
f = open('123.txt', 'r', encoding='utf-8') # 此处路径是相对路径,因为在同一个文件夹下的操作
# 2.操作文件
data = f.read(10) # 将所有内容读取出来,如果设置读取长度,按照规定长度读取数据 # 一行一行读取
line = f.readline()
print(line)
lines = f.readlines()
print(lines)
print(data) 按行一次性全部读出
l = []
for line in f:
# print(line)
l.append(line)
print(l) set1 = set()
for line in f:
# print(line)
set1.add(line)
print(set1) # 3.关闭文件
f.close() # 释放操作系统对文件的持有,变量f还被应用程序持有 # del f # 不需要该操作,系统自动回收
# 基础写
# 文件不存在:会新建文件,再操作文件
# 文件存在:先清空文件,再操作文件
w = open('b.txt', 'w', encoding='utf-8')
w.write('')
w.close()
day07----字符编码解码、文件操作(1)的更多相关文章
- Python之字符编码与文件操作
目录 字符编码 Python2和Python3中字符串类型的差别 文件操作 文件操作的方式 文件内光标的移动 文件修改 字符编码 什么是字符编码? ''' 字符编码就是制定的一个将人类的语言的字符与二 ...
- Python-字典、集合、字符编码、文件操作整理-Day3
1.字典 1.1.为什么有字典: 有个需求,存所有人的信息 这时候列表就不能轻易的表示完全names = ['stone','liang'] 1.2.元组: 定义符号()t = (1,2,3)tupl ...
- DAY07、字符编码和文件操作
一.字符编码 1.什么是字符编码? 人类能识别的是字符等高级标识符,电脑只能识别0,1组成的标识符,要完成人与机器之间的信息交流, 一定需要一个媒介,进行两种标识符的转化(两 ...
- Python 字符编码及其文件操作
本章节内容导航: 1.字符编码:人识别的语言与机器机器识别的语言转化的媒介. 2.字符与字节:字符占多少个字节,字符串转化 3.文件操作:操作硬盘中的一块区域:读写操作 注:浅拷贝与深拷贝 用法: d ...
- Python全栈开发之路 【第三篇】:Python基础之字符编码和文件操作
本节内容 一.三元运算 三元运算又称三目运算,是对简单的条件语句的简写,如: 简单条件语句: if 条件成立: val = 1 else: val = 2 改成三元运算: val = 1 if 条件成 ...
- DAY7 字符编码和文件操作
一.软件与python解释器打开文件的方法 1.软件打开文件读取数据的流程: 1. 打开软件 2. 往计算机发生一个打开文件的指令,来打开文件 3. 读取数据渲染给用户(存取编码不一致:乱码) 2.p ...
- Day 07 字符编码,文件操作
今日内容 1.字符编码:人识别的语言与机器识别的语言转换的媒介 2.字符与字节:字符占多少字节,字符串转换 3.文件操作:操作硬盘的一块区域 字符编码 重点:什么是字符编码 人类能识别的字符等高级标识 ...
- Python 入门基础6 --字符编码、文件操作1
今日内容: 1.字符编码 2.字符与字节 3.文件操作 一.字符编码 了解: cpu:将数据渲染给用户 内存:临时存放数据,断电消失 硬盘:永久存放数据,断电后不消失 1.1 什么是编码? 人类能够识 ...
- python基础——6(字符编码,文件操作)
今日内容: 1.字符编码: 人识别的语言与机器识别的语言转化的媒介 ***** 2.字符与字节: 字符占多少字节,字符串转化 *** 3.文件操作: 操作硬盘中的一块区域:读写操作 ...
- python字符编码与文件操作
目录 字符编码 字符编码是什么 字符编码的发展史 字符编码实际应用 编码与解码 乱码问题 python解释器层面 文件操作 文件操作简介 文件的内置方法 文件的读写模式 文件的操作模式 作业 答案 第 ...
随机推荐
- 华为P20无线投屏到电脑 绝地求生投射电脑
如今出门在外,必不可少的就是手机,如果没有了手机,每个人都会感觉没有安全感,感觉和世界失去了联系,我们每天每个人都在使用手机,但是作为华为手机用户的你,了解华为P20无线投屏到电脑是怎么操作的吗? 使 ...
- Openlayer3之C++接口在javaScript的封装使用
0.写在前面: 1)涉及的关键词定义: 传入:JavaScript向CAPI传值 传出:CAPI向JavaScript传值 2)关于类和结构体的封装,需要严格执行内存对齐,以防止读取越界,但是避免不了 ...
- Android深入四大组件(九)Content Provider的启动过程
前言 Content Provider做为四大组件之一,通常情况下并没有其他的组件使用频繁,但这不能作为我们不去深入学习它的理由.关于Content Provider一篇文章是写不完的,这一篇文章先来 ...
- Java 时间总结
转载请标明出处:http://blog.csdn.net/zhaoyanjun6/article/details/80613024 本文出自[赵彦军的博客] 时区 整个地球分为二十四时区,每个时区都有 ...
- split 分割 字符串(分隔符如:* ^ : | , .)
[1]单个符号作为分隔符 String address="上海|上海市|闵行区|吴中路"; String[] splitAddress=address.split("\\ ...
- Tmux 日常快捷键 及配置
使用Linux的人不管是开发人员.还是运维人员都不可避免的需要使用到终端模拟器(比如,gnome-terminal)去执行一些命令或者脚本. tmux可以将终端模拟器方便的切分为不同的小窗口如下图如示 ...
- 云ERP真的靠谱吗?
现在几乎每个IT系统或项目都要跟云挂上钩,跟数码产品必与“智能”扯上关系一样,否则在外行甚至同行眼里就是“矮小搓”.ERP领域也悄然刮起了云端化.国内ERP产品也借此机会想弯道超车,通过云化来抢夺被S ...
- Apache httpd.conf配置文件主要内容解释
1 ServerRoot 配置 ["ServerRoot" 主要用于指定Apache的安装路径,此选项参数值在安装Apache时系统会自动把Apache的路径写入.Windows安 ...
- CsQuery获取IDomObject元素的完整CSS选择器
一.方法说明 通过IDomObject元素,获取完整的CSS选择器,过滤HTML和BODY元素,自动将class.id添加到选择器上,优先添加class,无class再添加id.如: <html ...
- [20190321]smem的显示缺陷.txt
[20190321]smem的显示缺陷.txt1.smem 加入-m参数显示存在缺陷,map的信息不全:# smem -tk -m -U oracle -P "oraclepeis|ora_ ...