1.某企业有多名职工,各职工分别存有如下信息:
职工号、姓名、性别、职级、年龄、工资
用二重列表 clerks 存放,每个元素一名职工,示例数据如下:
clerks = [
['033164', '李四', '男', 'P12', 30, 14239], ['021796', '张三', '女', 'P09', 28, 36806] #其他职工的信息,略
]
(1) 完成两个参数的比较函数 compare,用于排序时通过模块
functools 中 cmp_to_key 函数接受,排序准则为工资降序、工资 相等时按职工号递增,该比较函数在排序时的使用格式如下:
sorted(clerks, key = cmp_to_key(compare))
(2) 完成排序时用于比较的单参数 lambda 函数,排序准则为
职级递减、职级相等时按年龄降序,该 lambda 函数在排序时的 使用格式如下,其中的“*” 为待完成的 lambda 函数:
sorted(clerks, key = )
2. 编写程序,按照输入的文件夹完全路径名,将该文件夹及其所有的子文件夹连同其中所有的文件名与后缀名,如果是英文的全部改成大写
3. 完成一个敏感词过滤程序,分别输入待过滤的文件名与保存过滤结果的文件名,将待过滤文件中单独的敏感词转换为等长度的“”字符。
设待过滤文件和敏感词均为纯英文文本文件,需要过滤的敏感词存放在文本文件“sensitive.txt”中,每行一个敏感词。
所谓单独的敏感词指的是单词前后可以有标点符号和空格,但是不能有字母,另外,待过滤的敏感词并不区分大小写。
第二题: 编写程序那个,是不是这个意思
import os
def func(path1):
filenames = os.listdir(path1)
for file in filenames:
path0 = os.path.join(path1, file)
if os.path.isfile(path0):
os.rename(path0, os.path.join(path, file.upper()))
else:
func(path0)
if __name__ == '__main__':
path = input('输入路径:')
func(path)
第三题:
import re
def func(file, file01, file02):
with open(file, 'r') as f0:
countent = f0.read()
with open(file01, 'r') as f1:
lines = f1.readlines()
for line in lines:
line = re.sub('\n', '', line)
repl = re.findall(f'\W{line}\W', countent, re.I)
# 去重
set_lst = set(repl)
for lst in set_lst:
# 将待过滤文件中单独的敏感词转换为等长度的“”字符 lst[0],{lst[-1]} 是单独的敏感词前后的标点符号或空格
lst0 = f'{lst[0]}""{lst[-1]}'
# ?和. 是正则的特殊符号
lst = lst.replace('?', '\?')
lst = lst.replace('.', '\.')
countent = re.sub(lst, lst0, countent, re.I)
with open(file02, 'w') as f2:
f2.write(countent)
if __name__ == '__main__':
file = input('输入待过滤的文件名路径:')
file01 = input('输入sensitive.txt路径:')
file02 = input('输入保存过滤结果的文件名路径:')
func(file, file01, file02)
嗯 好题
第一个自定义函数:
def compare(a,b):
#工资降序
if a['工资'] < b['工资']:
return 1
elif a['工资'] > b['工资']:
return -1
#工资相同按职工号升序
elif a['职工号'] > b['职工号']:
return 1
elif a['职工号'] < b['职工号']:
return -1
第二个:
sorted(clerks,key = lambda a: a['职级']+str(a['年龄']), reverse=True)