今天是读这本书的第三天(其实是第四天,昨天有点浪。。)今天就做了一个ex,ex23(ex22 是 一个复习的topic,提醒新手读者复习一下前面讲的内容,我就只在脑海里面过了一遍,这里就不一一列出了),不过这个练习里面可以说包含了比较多的东西,接下来就把代码先放上:
import sys
script, input_encoding, error = sys.argv
def main(language_file, encoding, errors):
line = language_file.readline()
if line:
print_line(line, encoding, errors)
return main(language_file, encoding, errors)
def print_line(line, encoding, errors):
next_lang = line.strip()
raw_bytes = next_lang.encode(encoding, errors = errors)
cookd_string = raw_bytes.decode(encoding, errors = errors)
print(raw_bytes, "<===>", cookd_string)
languages = open("languages.txt", encoding = "utf-8")
main(languages, input_encoding, error
这一个练习里面包含了一个引用import sys,两个函数:main(),print_line(),
一个关于编码、解码的知识,一个if 语句,一个return语句的应用(在这里较为特殊,要注意!),还有关于文件的操作。
1、先是import sys 调用系统模块,使用里面的argv,不懂的可以回头看看,
2、然后定义了main函数,函数的参数是文件名和解码方式还有errors(格式吧),在函数里面先是利用了读文件操作对line赋值,然后就来了一个重要的if语句,为什么重要捏,首先里面调用了另外一个函数print_line(),这个函数功能是打印里面的内容,具体是对文件里面的内容进行encode和decode操作,这里要提一下书中作者对这两个操作作用的巧妙记忆口诀:decode bytes(编码字节)、encode strings (解码字符串)
这里面涉及一个关于UTF-8的码字转换关系,有兴趣的可以去外面多查查,就是一个关于显示出来效果的东西,
再回到print_line()函数里面,看到对于文件解码 和 编码都做了打印,分别显示在一行的左右两边,用"<===>"分开,
好,回到if,我们看到调用了return方法进行对main函数的return,其实这里面就是对文件的行数进行循环,通过if语句进行判断,如果还有行数存在就进入if里面做一次return 读取下一行 readline(),如果没有下一行了,if 执行进不了里面,就结束main函数了,小小的利用if 和return 实现循环功能,这里有学问可以去探索,哈哈。
下面就是关于main函数的设置,参数的选择等,关于作者发的languages.txt 文件,就是每一行有一个人名,不过这个人名是用多种国家的语言写的,如果不是用UTF-8进行显示的话就会出现乱码的情况,这在windows 的终端里面是常见的,所以如果看到乱码不要惊讶,嘿。
好的,今天就到这。