文件操作和函数

Part 1 文件处理

1、编码问题

(1)请说明python2 与python3中的默认编码是什么?
(2)为什么会出现中文乱码?你能列举出现乱码的情况有哪几种?
(3)如何进行编码转换?
(4)#-*-coding:utf-8-*- 的作用是什么?
(5)解释py2 bytes vs py3 bytes的区别

2、文件处理

(1)r和rb的区别是什么?
(2)解释一下以下三个参数的分别作用
   open(f_name,'r',encoding="utf-8")

 

Part 2 函数基础

(1)写函数,计算传入数字参数的和。(动态传参)
(2)写函数,用户传入修改的文件名,与要修改的内容,执行函数,完成整个(3)文件的批量修改操作
(4)写函数,检查用户传入的对象(字符串、列表、元组)的每一个元素是否含有空内容。
(4)写函数,检查传入字典的每一个value的长度,如果大于2,那么仅保留前两个长度的内容,并将新内容返回给调用者。
dic = {"k1": "v1v1", "k2": [11,22,33,44]}
PS:字典中的value只能是字符串或列表
(5)解释闭包的概念

 

Part 3  函数进阶

(1)写函数,返回一个扑克牌列表,里面有52项,每一项是一个元组
例如:[(‘红心’,2),(‘草花’,2), …(‘黑桃A’)]

(2)写函数,传入n个数,返回字典{‘max’:最大值,’min’:最小值}

例如:min_max(2,5,7,8,4)
返回:{‘max’:8,’min’:2}

(3)写函数,专门计算图形的面积

其中嵌套函数,计算圆的面积,正方形的面积和长方形的面积
调用函数area(‘圆形’,圆半径) 返回圆的面积
调用函数area(‘正方形’,边长) 返回正方形的面积
调用函数area(‘长方形’,长,宽) 返回长方形的面积
def area():
    def 计算长方形面积():
        pass

    def 计算正方形面积():
        pass

    def 计算圆形面积():
        pass4)写函数,传入一个参数n,返回n的阶乘

例如:cal(7)
计算7*6*5*4*3*2*15)编写装饰器,为多个函数加上认证的功能(用户的账号密码来源于文件),要求登录成功一次,后续的函数都无需再输入用户名和密码

 

Part  4 生成器和迭代器

(1)生成器和迭代器的区别?
(2)生成器有几种方式获取value?
(3)通过生成器写一个日志调用方法, 支持以下功能

    根据指令向屏幕输出日志
    根据指令向文件输出日志
    根据指令同时向文件&屏幕输出日志
    以上日志格式如下

    2017-10-19 22:07:38 [1] test log db backup 3
    2017-10-19 22:07:40 [2]    user alex login success 
    #注意:其中[1],[2]是指自日志方法第几次调用,每调用一次输出一条日志
    代码结构如下

 def logger(filename,channel='file'):
    """
    日志方法
    :param filename: log filename
    :param channel: 输出的目的地,屏幕(terminal),文件(file),屏幕+文件(both)
    :return:
    """
    ...your code...

     #调用
     log_obj = logger(filename="web.log",channel='both')
     log_obj.__next__()
     log_obj.send('user alex login success')

 

Part 5 内置函数

(1)用map来处理字符串列表,把列表中所有人都变成sb,比方alex_sb

  name=['alex','wupeiqi','yuanhao','nezha']
(2)用filter函数处理数字列表,将列表中所有的偶数筛选出来   num
= [1,3,5,6,7,8]
(3)如下,每个小字典的name对应股票名字,shares对应多少股,price对应股票的价格   portfolio
= [ {'name': 'IBM', 'shares': 100, 'price': 91.1}, {'name': 'AAPL', 'shares': 50, 'price': 543.22}, {'name': 'FB', 'shares': 200, 'price': 21.09}, {'name': 'HPQ', 'shares': 35, 'price': 31.75}, {'name': 'YHOO', 'shares': 45, 'price': 16.35}, {'name': 'ACME', 'shares': 75, 'price': 115.65}   ]   计算购买每支股票的总价   用filter过滤出,单价大于100的股票有哪些

 

Part 6

1、请分别介绍文件操作中不同的打开方式之间的区别:

    模式    含义
    r    
    rb    
    r+    
    rb+    
    w    
    wb    
    w+    
    wb+    
    a    
    ab    
    a+    
    ab+

2、有列表 li = ['alex', 'egon', 'smith', 'pizza', 'alen'], 请将以字母“a”开头的元素的首字母改为大写字母;

3、有如下程序, 请给出两次调用show_num函数的执行结果,并说明为什么:

   num = 20

   def show_num(x=num):
       print(x)

   show_num()

   num = 30

   show_num()

4、有列表 li = ['alex', 'egon', 'smith', 'pizza', 'alen'], 请以列表中每个元素的第二个字母倒序排序;

5、有名为poetry.txt的文件,其内容如下,请删除第三行;

   昔人已乘黄鹤去,此地空余黄鹤楼。

   黄鹤一去不复返,白云千载空悠悠。

   晴川历历汉阳树,芳草萋萋鹦鹉洲。

   日暮乡关何处是?烟波江上使人愁。

6、有名为username.txt的文件,其内容格式如下,写一个程序,判断该文件中是否存在"alex", 如果没有,则将字符串"alex"添加到该文件末尾,否则提示用户该用户已存在;

   pizza
   alex
   egon

7、有名为user_info.txt的文件,其内容格式如下,写一个程序,删除id为100003的行;

   pizza,100001
   alex, 100002
   egon, 100003

8、有名为user_info.txt的文件,其内容格式如下,写一个程序,将id为100002的用户名修改为alex li;

   pizza,100001
   alex, 100002
   egon, 100003

9、写一个计算每个程序执行时间的装饰器;

10、lambda是什么?请说说你曾在什么场景下使用lambda?

11、题目:写一个摇骰子游戏,要求用户压大小,赔率一赔一。

    要求:三个骰子,摇大小,每次打印摇骰子数。

 

综合作业:

  现要求你写一个简单的员工信息增删改查程序,需求如下:

当然此表你在文件存储时可以这样表示

1,Alex Li,22,13651054608,IT,2013-04-01
2,Jack Wang,28,13451024608,HR,2015-01-07
3,Rain Wang,21,13451054608,IT,2017-04-01
4,Mack Qiao,44,15653354208,Sales,2016-02-01
5,Rachel Chen,23,13351024606,IT,2013-03-16
6,Eric Liu,19,18531054602,Marketing,2012-12-01
7,Chao Zhang,21,13235324334,Administration,2011-08-08
8,Kevin Chen,22,13151054603,Sales,2013-04-01
9,Shit Wen,20,13351024602,IT,2017-07-03
10,Shanshan Du,26,13698424612,Operation,2017-07-02

要求如下:

1.可进行模糊查询,语法至少支持下面3种查询语法:

    find name,age from staff_table where age > 22

    find * from staff_table where dept = "IT"

    find * from staff_table where enroll_date like "2013"
2.可创建新员工纪录,以phone做唯一键(即不允许表里有手机号重复的情况),staff_id需自增

    语法: add staff_table Alex Li,25,134435344,IT,2015-10-29
3.可删除指定员工信息纪录,输入员工id,即可删除

    语法: del from staff_table where  id=3
4.可修改员工信息,语法如下:

UPDATE staff_table SET dept="Market" WHERE  dept = "IT" 把所有dept=IT的纪录的dept改成Market
UPDATE staff_table SET age=25 WHERE  name = "Alex Li"  把name=Alex Li的纪录的年龄改成2
5.以上每条语名执行完毕后,要显示这条语句影响了多少条纪录。 比如查询语句 就显示 查询出了多少条、修改语句就显示修改了多少条等。

 

posted @ 2018-05-25 23:35  暮光微凉  阅读(665)  评论(0编辑  收藏  举报