python-study-07

上节课复习

上节课复习:
1、元组
元组就相当于不可变的列表
当我们要存放多个值,并且多个值是没有被修改的需求时,应该使用元组
t=('name',) #t=tuple(('name'))

总结:
1、可以存放多个任意类型的值
2、有序
3、不可变类型
2、字典
用于存放多个值,但是每一个值都有一个对应的key,key对值有描述性的
功能
当存放的值属于不同的状态是(年龄、身高、性别、体重),用字典可以明确地
区分不同值的用途
d={'name':'egon','age':18} #d=dict(...)
d=dict(a=1,b=2,c=3)

v=d.pop('a')
del d['a']

d.keys()
d.values()
d.items()

for k in d:
print(k,d[k])

for k in d.keys():
print(k,d[k])

for v in d.values():
pass

for k,v in d.items():
pass

d.get('a')

今日内容:
集合&关系运算
文件处理

字符编码

1 字符编码
将人类的字符编码/转换成计算机能识别的数字
这种转换必须遵循一套固定的标准,该标准无非是
人类字符与数字的对应关系,称之为字符编码表

A---->0000 0000
B---->0000 0001
c---->0000 0002
d---->0000 0003

bit:二进制位
Bytes:字节

ASCII码表:用1Bytes表示一个英文字符
1英文字符=8bit=1Bytes

GBK:用2Bytes表示一个中文字符,1Bytes去表示英文字符

unicode:内存中使用的是unicode编码,unicode把全世界的字符都建立好对应关系
用2Bytes去表示一个字符

0000 0000 0000 0000

utf-8 #unicode tranform format-8
utf-8 用1Bytes表示英文,用3Bytes表示中文

#字符编码需要记住的概念
#01 内存中固定使用unicode编码,我们唯一可以改变的存储到硬盘时使用的编码
#02 要想保证存取文件不乱码,应该保证文档当初是以什么编码格式存的,就应该以什么编码格式去读取

#03 python3解释器默认编码是UTF-8 (所以文件如果是是gbk存储的 从硬盘加载到内存这一步就是错误的)
python2解释器默认编码是ASCII

在python2中有两种字符串编码格式
1、unicode:
x=u'上'
2、unicode编码后的结果
x='上' #如果文件头为coding:utf-8,那么"上"被存成utf-8格式的二进制

在python3只有一种字符串编码格式:
1、unicode
x='上’

#04 编码与解码 编码对应从内存到硬盘,解码对应从硬盘到内存
unicode-------编码encode-------->gbk
unicode<-------解码decode--------gbk

#***
#coding:gbk
x='上’
x.decode('gbk')

#coding:gbk
x=u'上'
x.encode('gbk')
x.encode('utf-8')

#在python3中(*****)
x='上'
x只能进行编码
x.encode('gbk')

总结python2与python3:
(***)
在python2中的字符串类型str都是unicode按照文件头的指定的编码,编码之后的结果
在python2中也可以制造unicode编码的字符串。需要在字符串前加u

(*****)
在python3中的字符串类型str都是unicode编码的
所以python3中的字符串类型可以编码成其他字符编码格式,编码的结果
是bytes类型

集合

http://www.cnblogs.com/linhaifeng/articles/7133357.html

作业

#作业一: 三级菜单
#要求:
打印省、市、县三级菜单
可返回上一级
可随时退出程序

#作业二:请闭眼写出购物车程序
#需求:
用户名和密码存放于文件中,格式为:egon|egon123
启动程序后,先登录,登录成功则让用户输入工资,然后打印商品列表,失败则重新登录,超过三次则退出程序
允许用户根据商品编号购买商品
用户选择商品后,检测余额是否够,够就直接扣款,不够就提醒
可随时退出,退出时,打印已购买商品和余额

预习:文件处理,函数

猜你喜欢

转载自www.cnblogs.com/xujinjin18/p/9122872.html