结论:在编写py的程序的时候,是没有语法的限制的,编辑的结果跟编写一个普通的文本文件是没有任何区别。只有把py程序交给python解释器并且在运行的第三个阶段才有了语法的意义
第一阶段:先启动python解释器这个软件
第二阶段:把py文件读取内存
第三阶段:解释执行,识别语法
人类的字符翻译成0或1的数字,翻译的过程必须遵循一个标准:字符与数字一一对应的关系。这个标准称之为字符编码表。
unicode
现阶段的硬盘都是用 utf-8的,内存中统一采用unicode,浪费空间来换取可以转换成任意编码(保证不乱码)硬盘可以采用各种编码,如utf-8,保证存放于硬盘或者基于网络传输的数据量很小,提高传输效率与稳定性。
我们能控制的只是存在硬盘上的编码
ppython3解释器,默认utf-8编码
python解释器,默认ASCII编码
文件头的作用#coding:utf-8 告诉python解释器,用指定的字符编码
#-*-coding:utf-8-*-
会识别python语法,定义的字符串类型又涉及到字符编码的概念
python2:
字符串分为两个形式:
x='上' python2的str类型会按照文件头指定的编码来存'上'
python3
str:被存成了unicode
unicode--->编码encode--->gbk
gbk----->解码decode----->unicode
保证不乱码的核心法则就是:
字符按照什么标准而编码的,就要按照什么标准解码,此处的标准指的就是字符编码