Python 字符编码-文件处理
.read #读取所有内容,光标移动到文件末尾
.readable #判断文件是否可读
.readline #读取一行内容,光标移动到第二行首部
.readlines #读取每一行内容,存放于列表中
.write #针对文本模式的写,需要自己写换行符
.writable #判断文件是否可写
.writelines #向文件中写入一序列的字符串
.close #关闭打开的文件
encoding='' 用哪个编码打开
.encode #编码
.decode #解码 上节课复习:
1.集合类型:
两大用途:关系运算+去重
三个注意点:
1.集合内元素必须为不可变类型
2.集合内元素不能重复
3.集合内元素无序 去重局限性:
1.被去重的对象包含的多个值必须都为不可变类型
2.去重的结果为集合,无法保证原来的顺序 1.什么是字符编码
字符-----编码(字符编码表)------->二进制 ACSII: 只能表示英文字符,用1bytes对应一个英文字符
内存:ACSII
硬盘:ACSII
GBK:可以表示中文和英文字符,用1bytes对应一个英文字符,2bytes对应一个中文字符
内存:GBK
硬盘:GBK Shift-JIS: 日本
内存:Shift-JIS
硬盘:shift-JIS Euc-kr: 韩国
内存:Euc-kr
硬盘:Eus-kr Unicode: 可以对应万国字符,统一用2bytes对应一个字符
内存:Unicode
硬盘:Unicode 两大特点:
1,可以兼容万国字符
2.与万国字符编码都有一种数字与数字的对应关系
GBK数字------解码decode-------->Unicode数字
强调:此时计算机只能使用Unicode与字符的对应关系 utf-8:
3Bytes对应一个中文字符
2Bytes对应一个英文字符
保证不乱码的关键:
1.字符当初以什么编码存放的,就应该以什么编码取解码 Python test.py
在Python2中:
1.解释器默认使用的编码是ASCII
2.有两种字符串类型:
str:x="上" 文件头指定的编码格式的二进制
Unicode:x=u"上" 存成Unicode格式的二进制
ps:
在Python3中:
1.(执行Python程序的第二个阶段)解释器在将test.py当普通的文本文件读入内存时默认使用的编码是UTF-8
2.(执行Python程序的第三个阶段,开始识别语法),会将字符类型的值开辟一个内存空间存入Unicode格式的二进制
即Python3中的str类型是Unicode编码的二进制 3.字符串类型 .encode 编码
.decode 解码 文件头:
在文件首行写上: coding:utf-8
就是在告诉Python下面的代码用UTF8读取 2文件处理:
1.什么是文件
文件是操作系统为用户/应用程序提供的一种操作硬盘的抽象单位
2.为何要用文件:
用户/应用程序对文件的读写操作会由操作系统转换成具体的硬盘操作
所以用户/应用程序可以通过简单的读\写文件来间接的控制复杂的硬盘的存取操作
实现将内存中的数据永久保存到硬盘中
3.如何用文件
open 是向操作系统发送请求,要求操作系统打开文件
open(r'文件路径') 路径前都要加r
f = open(r'a.txt',encoding='utf-8') 相对路径
print(f.read()) f的值是一个文件对象
f.close() 向操作系统发送请求,要求操作系统关闭打开的文件
强调:一定要在程序结束前关闭打开的文件 上下文管理 with
with open(r'a.txt',encoding='utf-8') as f:
print(f.read())
操作完打开文件后不用再去写关闭文件指令,with会自动帮你管理 open 打开, 打开文件,拿到一个文件对象,文件对象就相当于一个遥控器,可以向操作系统发送指令
read 读取 读写文件,向操作系统发送读写文件指令
encoding='' 用哪个编码打开
.close 关闭 关闭文件,回收操作系统的资源
with 上下文管理
mode 模式 4.文件的打开模式
r: 只读模式(默认的)
1.当文件不存在时,会报错
2.当文件存在时,文件指针指向文件的开头
w: 只写模式
1.当文件不存在时,新建一个空文档
2.当文件存在时,清空文件内容,文件指针跑到文件的开头
a: 值追加写模式
1.当文件不存在时,新建一个空文档
2.当文件存在时,文件指针指向文件末尾
5.控制读写文件单位的方式(必须与r\w\a连用)
t: 文本模式(默认的),一定要指定encoding参数
优点: 操作系统会将硬盘中二进制数字解码成Unicode然后返回
强调: 只针对文本文件有效
b: 二进制模式(一定不能指定encoding参数)
优点: 没有局限性
Python 字符编码-文件处理的更多相关文章
- python字符编码-文件操作
字符编码 字符编码历史及发展 为什么有字符编码 ''' 原因:人们想要将数据存入计算机 计算机的能存储的信息都是二进制的数据 内存是基于电工作的,而电信号只有高低频两种,就用01来表示高低电频,所以计 ...
- Python字符编码讲解
声明:本文参考 Python字符编码详解 在计算机中我们不管用什么语言和程序,最终数据在计算机中的都是字节码(也就是01形式)的形式存在的,如果 计算机直接把字节码显示在屏幕上,很明显一般人看不懂字节 ...
- 深入理解Python字符编码--转
http://blog.51cto.com/9478652/2057896 不论你是有着多年经验的 Python 老司机还是刚入门 Python 不久,你一定遇到过UnicodeEncodeError ...
- 深入理解Python字符编码
不论你是有着多年经验的 Python 老司机还是刚入门 Python 不久,你一定遇到过UnicodeEncodeError.UnicodeDecodeError 错误,每当遇到错误我们就拿着 enc ...
- Python字符编码详解,str,bytes
什么是明文 “明文”是可以是文本,音乐,可以编码成mp3文件.明文可以是图像的,可以编码为gif.png或jpg文件.明文是电影的,可以编码成wmv文件.不一而足. 什么是编码?把明文变成计算机语言 ...
- Python字符编码补充
字符编码: Python字符编码贯穿Python学习的始终,现在应用的是Python2中字符编码的问题是很多的. 这次是要彻底解决Python字符编码的问题!!! 1 字符编码的发展过程: 1 .AS ...
- python --- 字符编码学习小结(二)
距离上一篇的python --- 字符编码学习小结(一)已经过去2年了,2年的时间里,确实也遇到了各种各样的字符编码问题,也能解决,但是每次都是把所有的方法都试一遍,然后终于正常.这种方法显然是不科学 ...
- 转1:Python字符编码详解
Python27字符编码详解 声明 一 字符编码基础 1 抽象字符清单ACR 2 已编码字符集CCS 3 字符编码格式CEF 31 ASCII初创 311 ASCII 312 EASCII 32 MB ...
- 转2:Python字符编码详解
1. 字符编码简介 1.1. ASCII ASCII(American Standard Code for Information Interchange),是一种单字节的编码.计算机世界里一开始只有 ...
随机推荐
- centos 6.2 pptp 客户端 安装(转载)
转自:http://www.lnmpblog.com/archives/611 centos 6.2 64.bit的桌面版本.配置vpn客户端. 步骤: 1.yum -y install pptp 2 ...
- bzoj P1979 华容道【bfs+spfa】
调死我了-- 首先观察移动方式,需要移动的格子每次移动到相邻格子,一定是先把空白格子挪过去,所以我们得到一种做法,就是bfs预处理出每一个格子的四联通格子之间的空白格子移动距离建边,注意这个移动是不能 ...
- 无法生成DH密钥对Could not generate DH keypair
Source from here Add this library to classpath(following is maven project) <dependency> < ...
- maven学习-搭建环境
1.Maven是基于项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的软件项目管理工具. 2.下载: maven.apache.org 3.bin目录包含mvn的运行脚本: ...
- SQL 初级教程学习(四)
1. union,union all SELECT E_Name FROM Employees_ChinaUNIONSELECT E_Name FROM Employees_USA 默认地,UNION ...
- [转]Visual F# Samples and Walkthroughs
本文转自:http://msdn.microsoft.com/en-US/library/vstudio/ee241126.aspx This topic provides links to samp ...
- 关于react native在window下运行安卓的时候报 could not connect to development server
当出现这种问题是网上的解答方案都是一模一样的! 我这边先给个地址讲的是解决方案http://blog.csdn.net/qq_25827845/article/details/52974991 但是我 ...
- spring jdbc 批处理插入主健重复的数据
1.有事务:当调用spring jdbc 的批处理的时候,在实现层加入事物,只要有插入异常的数据,整个批处理操作都会回滚.事务保证操作的原子性. 2.无事务:当没有事务的时候,批处理插入数据的时候,若 ...
- html中 accept 属性
1.HTML <input> 标签的 accept 属性 在文件上传中使用 accept 属性,本例中的输入字段可以接受 GIF 和 JPEG 两种图像: <form> < ...
- ijkplayer seekTo回跳以前从指定位置播放解决办法
相信在使用ijkplayer播放视频时候,大部分情况会遇到SEEKTO的问题,就是拖动后,不会从拖动结束的位置播放,而是大部分拖动后,会回跳一段时间,甚至从头开始播放. 官方称这 是正常的,因为视频拖 ...