2018.3.14
今天Stephen Hawking去世了.默哀
1.错误处理机制
- 使用try except来抛出错误,好处是可以多级检测.A调用了B,B调用了C.只要在A中的合适的位置检查了错误,C中的错误也可以被检测出来.
try:
print('try...')
r = 10 / int('2')
print('result:', r)
except ValueError as e:
print('ValueError:', e)
except ZeroDivisionError as e:
print('ZeroDivisionError:', e)
else:
print('no error!')
finally:
print('finally...')
print('END')
2.文件简单操作
with open("test",'r') as f:
for line in f.readlines():
print(line)
with open("test",'w') as f:
for i in range(101):
f.write("No.%s line" % i )
如果不用with这种语法,中途如果IO出了BUG,没有使用f.close()的话,文件的内容很可能没被保存下来.
ps:二进制读写就是rb,wb.写数据的时候,write函数需要把期望的内容进行编码:
with open("test",'wb') as f:
f.write('中文'.encode('utf-8'))
- file-like-object:
像open()函数返回的这种有个read()方法的对象,在Python中统称为file-like Object。除了file外,还可以是内存的字节流,网络流,自定义流等等。file-like Object不要求从特定类继承,只要写个read()方法就行
3.序列化
把变量从内存中变成可存储或传输的过程称之为序列化
web的话一般用JSON,给一个python转JSON格式的对应:
- 直接把数据转换
>>> import json
>>> d = dict(name='Bob', age=20, score=88)
>>> json.dumps(d)
'{"age": 20, "score": 88, "name": "Bob"}'
>>> json_str = '{"age": 20, "score": 88, "name": "Bob"}'
>>> json.loads(json_str)
{'age': 20, 'score': 88, 'name': 'Bob'}
- 把class转换成JSON会麻烦一点,写一个转换函数
def student2dict(std):
return {
'name': std.name,
'age': std.age,
'score': std.score
}
>>> print(json.dumps(s, default=student2dict))
{"age": 20, "name": "Bob", "score": 88}
- 如果嫌麻烦,也可以用lambda返回一般class都有的一个
__dict__
属性
print(json.dumps(s, default=lambda obj: obj.__dict__))
当然也有例外,比如定义了__slots__
的class
- 把JSON反序列化成一个class实例
loads()方法首先转换出一个dict对象,然后,我们传入的object_hook函数负责把dict转换为class实例
def dict2student(d):
return Student(d['name'], d['age'], d['score'])
>>> json_str = '{"age": 20, "score": 88, "name": "Bob"}'
>>> print(json.loads(json_str, object_hook=dict2student))
<__main__.Student object at 0x10cd3c190>