Python文件与函数练习题
练习题
文件处理相关
编码问题
请说明python2 与python3中的默认编码是什么?
python2默认是ASCII码,python3默认是utf-8
为什么会出现中文乱码?你能列举出现乱码的情况有哪几种?
sys.stdout.encoding,默认就是locale的编码,print会用sys.stdout.encoding去encode()成字节流,交给terminal显示。所以locale需要与terminal一致,才能正确print打印出中文。
sys.setdefaultencoding(‘utf8’),用于指定str.encode() str.decode()的默认编码,默认是ascii。
以下几种(local 为软件运行时的语言环境):
终端为UTF-8,locale为zh_CN.GBK
终端为UTF-8,locale为zh_CN.UTF-8
终端为GBK,locale为zh_CN.GBK
终端为GBK,locale为zh_CN.UTF-8如何进行编码转换?
字符串在python内部中是采用unicode的编码方式,所以其他语言先decode转换成unicode编码,再encode转换成utf8编码。
#-*-coding:utf-8-*-的作用是什么?#coding:utf-8 #.py文件是什么编码就需要告诉python用什么编码去读取这个.py文件。
解释py2 bytes vs py3 bytes的区别
Python 2 将 strings 处理为原生的 bytes 类型,而不是 unicode(python2 str == bytes),
Python 3 所有的 strings 均是 unicode 类型(python2 中需要通过 unicode )
string -> encode -> bytes
bytes -> decode -> string
文件处理
r和rb的区别是什么?
r 读模式
rb 二进制读2.解释一下以下三个参数的分别作用
open(f_name,'r',encoding="utf-8")
f_name 文件名
r 模式
encoding 编码方式
函数:
函数使用
写函数,计算传入数字参数的和。(动态传参)
def func_sum(x, y):
return x + y
或
lambda x,y:x+y写函数,用户传入修改的文件名,与要修改的内容,执行函数,完成整个文件的批量修改操作
import os
def modify_file(file_name,content,newstr):
new_file_name = '%sfile_name' %'new.'
f_new = open(new_file_name, 'w')
if os.path.exists(file_name):
with open(file_name,'r+') as f:
for line in f:
if content in line:
line = line.replace(content, newstr)
f_new.write(line)
f_new.close()
os.rename(new_file_name, file_name)
else:
exit('file is not exist !!!')写函数,检查用户传入的对象(字符串、列表、元组)的每一个元素是否含有空内容。
def isNull(p_obj):
for item in p_obj:
if item.strip() == '':
return True
else:
return False
a = [' ','','']
b = ['','','']
c = 'ab c'
print(isNull(a))
print(isNull(c))
print(isNull(b))写函数,检查传入字典的每一个value的长度,如果大于2,那么仅保留前两个长度的内容,并将新内容返回给调用者。
def two_len(**kwargs):
for k, v in kwargs.items():
if len(v) > 2:
kwargs[k] = v[:2]
return kwargs
print(two_len(x='', y='', c='byw'))
闭包
内部函数包含对外部作用域而非全局作用域变量的引用,该内部函数称为闭包函数写函数,返回一个扑克牌列表,里面有52项,每一项是一个元组
例如:[(‘红心’,2),(‘草花’,2), …(‘黑桃A’)]
def cards():
type_li = ['红心', '草花', '黑桃','梅花']
num = list(range(2, 11))
num.extend('JQKA')
return [(x, y) for x in type_li for y in num ]
print(len(cards()), cards())
写函数,传入n个数,返回字典{‘max’:最大值,’min’:最小值}
def max_min_dic(*args):
min_v = min(args)
max_v = max(args)
return {'max':max_v,'min':min_v}
print(max_min_dic(2,3,6,7,9))写函数,传入一个参数n,返回n的阶乘
from functools import reduce
def factorial(n):
if n == 0:
return 0
elif n == 1:
return 1
else:
return reduce(lambda x, y: x*y ,list(range(1, n)))
print(factorial(5))编写装饰器,为多个函数加上认证的功能(用户的账号密码来源于文件),要求登录成功一次,后续的函数都无需再输入用户名和密码
user_dic={
'user':None,
'is_authenticate':False
} def read_file():
with open('USER.TXT','r') as f:
s = f.read().strip(',')
user_info = eval(s)
return user_info def auth(user_info):
username = input("account:").strip()
password = input("password:").strip()
print(user_info)
if username in user_info['name'] and password in user_info['password']:
print("success")
user_dic['user'] = username
user_dic['is_authenticate'] = True
return user_dic
else:
print("Failure")
return ''
def login_required(func): def inner(*args, **kwargs): if args[0].get('is_authenticate'): ret = func(*args, **kwargs) else: exit('need authenticate') return ret return inner @login_required def print_info(acc_data): print('进入') user_info = read_file() user_data = auth(user_info) print(user_data) print_info(user_data)
生成器和迭代器
生成器有几种方式获取value?
`next和for循环
内置函数
用map来处理字符串列表,把列表中所有人都变成good,比方alex_good
name=['alex','wupeiqi','yuanhao','nezha']
print(list(map(lambda x:x+'good',name)))
用filter函数处理数字列表,将列表中所有的偶数筛选出来
num = [1,3,5,6,7,8]
print(list(filter(lambda x:x%2==0,num)))
如下,每个小字典的name对应股票名字,shares对应多少股,price对应股票的价格
计算购买每支股票的总价
用filter过滤出,单价大于100的股票有哪些
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}
]
print([(item['name'],item['shares']*item['price']) for item in portfolio])
print(list(filter(lambda item:item['price']>100, portfolio)))4.有列表 li = ['alex', 'egon', 'smith', 'pizza', 'alen'], 请将以字母“a”开头的元素的首字母改为大写字母;
li = ['alex', 'egon', 'smith', 'pizza', 'alen']
print([item.capitalize() if item.startswith('a') else item for item in li])5.有如下程序, 请给出两次调用
show_num函数的执行结果,并说明为什么:num = 20
def show_num(x=num):
print(x)
show_num()
num = 30
show_num() 20
20
如果函数收到的是一个不可变对象(比如数字、字符或者元组)的引用,就不能直接修改原始对象,相当于通过“传值’来传递对象。6. 有列表 li = ['alex', 'egon', 'smith', 'pizza', 'alen'], 请以列表中每个元素的第二个字母倒序排序
li = ['alex', 'egon', 'smith', 'pizza', 'alen']
print(list(sorted(li,key=lambda x :x[1],reverse=True)))
综合
- 有名为
poetry.txt的文件,其内容如下,请删除第三行: """
昔人已乘黄鹤去,此地空余黄鹤楼。
黄鹤一去不复返,白云千载空悠悠。
晴川历历汉阳树,芳草萋萋鹦鹉洲。
日暮乡关何处是?烟波江上使人愁。
""" import os str = '晴川历历汉阳树,芳草萋萋鹦鹉洲'
f_name = 'poetry.txt'
f_new_name = '%s.new'% f_name
f_new = open(f_new_name,'w',encoding='utf-8')
with open(f_name,'r', encoding='utf-8') as f:
for line in f:
if str in line:
line = ''
f_new.write(line)
else:
f_new.write(line)
f_new.close()
os.replace(f_new_name, f_name)- 有名为
username.txt的文件,其内容格式如下,写一个程序,判断该文件中是否存在"alex", 如果没有,则将字符串"alex"添加到该文件末尾,否则提示用户该用户已存在 import os str = 'alex'
f_name = 'username.txt'
f_new_name = '%s.new'% f_name
with open(f_name,'r+', encoding='utf-8') as f:
for line in f:
if str in line:
print('the user {} already exist'.format(str))
break
else:
f.write('\n%s' % str)有名为user_info.txt的文件,其内容格式如下,写一个程序,删除id为100003的行;
"""
有名为user_info.txt的文件,其内容格式如下,写一个程序,删除id为100003的行
pizza,100001
alex, 100002
egon, 100003
""" f_name = r'user_info.txt'
f_new_name = '%s.new'%f_name
del_id = ''
f_new = open(f_new_name, 'w', encoding='utf-8')
with open(f_name, 'r', encoding='utf-8') as f:
for line in f:
if del_id in line:
pass
else:
f_new.write(line)
f_new.close()
os.replace(f_new_name,f_name)有名为user_info.txt的文件,其内容格式如下,写一个程序,将id为100002的用户名修改为
alex li;"""
有名为user_info.txt的文件,其内容格式如下,写一个程序,将id为100002的用户名修改为alex li
pizza,100001
alex,100002
egon,100003
"""
f_name = r'user_info.txt'
f_new_name = '%s.new'%f_name
update_id = ''
update_name = 'alex li'
f_new = open(f_new_name, 'w', encoding='utf-8')
with open(f_name, 'r', encoding='utf-8') as f:
for line in f:
if update_id in line:
line = ','.join([update_name, update_id])
f_new.write(line+'\n')
else:
f_new.write(line)
f_new.close()
os.replace(f_new_name,f_name)写一个计算每个程序执行时间的装饰器;
import time
from functools import wraps
def timer(func):
@wraps(func)
def wrapper(*args,**kwargs):
start = time.time()
ret = func(*args, **kwargs)
print('{} execute {}s'.format(func.__name__,time.time()-start))
return ret
return wrapper @timer # fib = timer(fib)
def fib(n):
a, b = 0, 1
for i in range(n):
print(b)
a, b = b, a+b
return b fib(100)lambda是什么?请说说你曾在什么场景下使用lambda?
好处:
1.lambda函数比较轻便,即用即扔,适合完成只在一处使用的简单功能
2.匿名函数,一般用来给filter,map这样的函数式编程服务
3.作为回调函数,传递给某些应用,比如消息处理题目:写一个摇骰子游戏,要求用户压大小,赔率一赔一。
要求:三个骰子,摇大小,每次打印摇骰子数。
import random def roll_dice(numbers=3, points=None):
"""
定义骰子,循环三次
:param numbers:
:param points:
:return:
"""
if points is None:
points = [] print('----- 摇骰子 -----')
while numbers > 0:
point = random.randrange(1, 7)
# print('roll dice is {}'.format(point))
points.append(point)
numbers -= 1 return points def roll_result(total):
"""
定义大小,三个大或者一个小两个大。三个小或者两个小一个大
:param total:
:return:
""" is_big = 11 <= total <= 18
is_small = 3 <= total <= 10
if is_big:
return "big"
elif is_small:
return "small" def start_game():
money = 1000
while money > 0:
print('----- 游戏开始 -----')
choices = ['big', 'small']
your_choice = input("请下注, big or small")
your_bet = input("下注金额:")
if your_choice in choices:
if your_bet.isdigit():
points = roll_dice()
total = sum(points)
you_win = your_choice == roll_result(total)
if you_win:
print("骰子点数", points, total)
money += int(your_bet)
print("恭喜, 你赢了%s元, 你现在的本金%s 元" % (your_bet, money))
else:
print("骰子点数", points, total)
money -= int(your_bet)
print("很遗憾, 你输了%s元, 你现在的本金%s 元" % (your_bet, money)) else:
print('格式有误,请重新输入')
else:
print('格式有误,请重新输入')
else:
print("game over") start_game()
Python文件与函数练习题的更多相关文章
- Python文件操作函数os.open、io.open、内置函数open之间的关系
Python提供了多种文件操作方式,这里简单介绍os.open.io.open.内置函数open之间的关系: 一.内置函数open和io.open实际上是同一个函数,后者是前者的别名: 二.os.op ...
- Python 文件操作函数
这个博客是 Building powerful image classification models using very little data 的前期准备,用于把图片数据按照教程指示放到规定的文 ...
- Python 文件修改-函数介绍
上节课复习:1.字符编码 1.1 如何解决乱码问题: 字符存取使用的编码标准不一致 1.2 文件头 在文件的首行写入文件头,用于控制Python解释器读取py文件内容时使用的编码 #coding:文件 ...
- 导入其他python文件或者python文件的函数
from abc import xxx 从abc的py文件导入一个具体的函数或者类 import abc 直接导入文件 a.b写在同一个文件目录下,a要使用b,直接import就可以了
- Python文件操作与函数目录
文件操作 python文件操作 函数 Python函数学习——初步认识 Python函数学习——作用域与嵌套函数 Python函数学习——匿名函数 python内置函数 Python函数学习——递归 ...
- python内置函数,lambda表达式,文件读写
Lambda表达式: lambda是个匿名函数,自动加return返回 a={ 6:2,8:0, 1:4,-5:6,99:11,4:22} print(sorted(a.items()))#按key排 ...
- python内置函数print输出到文件,实现日志记录的功能
# bulid time 2018-6-22 import os import time def log(*args, **kwargs): # *kargs 为了通用 可不传 rule = &quo ...
- python基础-4 函数参数引用、lambda 匿名函数、内置函数、处理文件
上节课总结 1.三元运算 name=“name1”if 条件 else “name2” 2.深浅拷贝 数字.字符串 深浅,都一样 2.其他 浅拷贝:只拷贝第一层 深拷贝:不拷贝最后一层 3.set集合 ...
- python基础四(json\os\sys\random\string模块、文件、函数)
一.文件的修改 文件修改的两种思路: 1.把文件内容拿出来,做修改后,清空原来文件的内容,然后把修改过的文件内容重新写进去. 步骤: 1.打开文件:f=open('file','a+') #必须用a ...
随机推荐
- oracle 查看表空间使用情况
查看表空间剩余: ||'M' from dba_free_space group by tablespace_name 查看表空间总大小.使用大小.剩余大小,使用率.剩余率 ) useded, tru ...
- 2018.12.19 atcoder Iroha and a Grid(组合数学)
传送门 组合数学好题. 给你一个hhh行www列的网格,其中左下角aaa行bbb列不能走,问从左上角走到右下角有多少种走法(每次只能向右或者向下) 我们考虑分步计数. 我们一共能走的区域是总网格区域去 ...
- 2018.11.28 poj3294 Life Forms(后缀数组+双指针)
传送门 后缀数组经典题目. 我们先把所有的字符串都接在一起. 然后求出hththt数组和sasasa数组. 然后对于sasasa数组跑双指针统计答案. 如果双指针包括进去的属于不同字符串的数量达到了题 ...
- Codeforces Round #538 (Div. 2) E 随机数生成
https://codeforces.com/contest/1114/problem/E 题意 交互题,需要去猜一个乱序的等差数列的首项和公差,你能问两种问题 1. 数列中有没有数比x大 2. 数列 ...
- this指针和const成员函数
1.this指针 1)this指针是成员函数的隐式参数,成员函数通过this指针来访问调用它自己的那个对象,成员函数对各成员的访问均通过this进行 2)当某个对象调用它的成员函数时,编译器会把这个对 ...
- 开机logo以及两种修改开机动画方法
Android开机画面总共有三屏 一.第一屏:开机logo 1.选张png格式的图片,在Linux任意下执行(安装工具): sudo apt-get install pnmtoplainpm 2.在所 ...
- 诡异的 ERROR 1045 (28000): Access denied for user 错误
问题描述: 用户已建,权限已赋予.long long ago这个用户是可以正常访问的,但是今天它就不能访问了.报错如下: ERROR 1045 (28000): Access denied for u ...
- WEB版一次选择多个文件进行批量上传(swfupload)的解决方案
说明:功能完全支持ie和firefox浏览器! 一般的WEB方式文件上传只能使用FileUpload控件进行一个文件一个文件的进行上传,就算是批量上传,也要把文件一个一个的添加到页面,无法如windo ...
- 自定义消息的操作方法ON_MESSAGE(..)
- CentOS 5 上配置 Redmine 和 Git
现在我们用 Trac + Git 来管理所有的项目,早些时候是由 Trac + Subversion 管理的,和 Git 比较起来 Subversion 简直就是龟速.虽然我们前段时间换成了 Git ...