1、文件处理相关
1、编码问题
①python2与python3中的默认编码:
py2默认使用ASCII码,py3默认使用utf-8
②为什么会出现中文乱码,中文乱码的情况有哪些?
#sys.stdout.encoding,默认就是locale的编码,print会用sys.stdout.encoding去encode()成字节流,交给terminal显示。所以,locale需要与terminal一致,才能正确print打印出中文
下面还是直接给大家介绍下可以正确打印出中文的方式咯:
终端为utf-8,locale为zh_CN.GBK
终端为utf-8,locale为zh_CN.UTF-8
终端为GBK,locale为zh_CN.GBK
终端为GBK,locale为zh_CN.UTF-8
2、如何进行编码转换
字符串在python内部中是采用unicode的编码方式,所以其他语言先decode转换成unicode编码,再encode转换成utf-8编码。
3、#-*-coding:utf-8-*-的作用
起到编码声明的作用
4、解释py2 bytes vs py3 bytes的区别
python2将strings处理为原生的bytes类型,而不是unicode(python2 str == bytes)
python3所有的string均是unicode类型(python3需要通过unicode)
string -> encode -> bytes
bytes -> decode -> string
5、文件处理
①r和rb的区别:r是读模式,而rb是二进制读模式,即数据读到的内容直接是二进制bytes模式
②解释open中以下三个参数的作用:
open(f_name,'r',encoding='utf-8'):f_name是文件名,r是模式,encoding是编码方式
2、函数基础
1、写函数,计算传入参数的和。(动态传参)
def func_sum(x,y):
return x+y 或 lambda x,y:x+y
2、写函数,用户传入修改的文件名,与要修改的内容,执行函数,完成整个文件的批量修改操作
#修改列表中字符串(首字母大写)
def file_daxie(file): a = [] for i in file: b = i.capitalize() a.append(b) print(a)
3、写函数,检查用户传入的对象(字符串、列表、元组)的每一个元素是否有空内容
def file_k(file): n = 0 for i in file: if i == ' ': n += 1 print('有%s个空'%n)
4、写函数,检查传入字典的每一个value的长度,如果大于2,那么仅保留前两个长度的内容,并将新内容返回给调用者。
dic = {'k1':'v1v1','k2':[11,22,33,44]} def func(i): for k,v in i.items(): if len(v) > 2: dic[k] = v[ :2] else: continue return i print(func(dic))
5、解释闭包的概念
闭包(closure)是函数式编程的重要的语法结构。函数式编程是一种编程范式(注:面向过程编程和面向对象编程也是编程范式)
闭包是一种组织代码的结构,它同样能提高代码的可重复使用性。
3、函数进阶
1、写函数,返回一个扑克牌列表,里面有52项,每一项是一个元组
例如:[(‘红心’,2),(‘草花’,2),……(‘黑桃’,‘A’)]
def cards(): num = [] for i in range(2, 11): num.append(i) num.extend(['J', 'Q', 'K', 'A']) type = ['红心', '草花', '方块', '黑桃'] result = [] for i in num: for j in type: result.append((j,i)) return result print(cards())
2、写函数,传入n个数,返回字典{‘max’:最大值,‘min’:最小值}
例如:min_max(2,5,7,8,4)
返回:{‘max’:8,‘min’:2}
def max_min(*args): the_max = args[0] the_min = args[0] for i in args: if i > the_max: the_max = i else: the_min = i return {'max': the_max, 'min': the_min} res = max_min(2, 4, 6, 48, -16, 486) print(res)