-
为函数写一个装饰器,在函数执行之后输出 after
def after(func): def test(*args, **kwarg): result = func(*args, **kwarg) print("after") return result return test @after def func(x, y): z = x + y print(z) func(5, 6)
-
为函数写一个装饰器,把函数的返回值 +100 然后再返回。
def after(func): def test(*args, **kwarg): result = func(*args, **kwarg) print(result + 100) return result return test @after def func(x, y): z = x + y print(z) return z func(5, 6)
-
写一个装饰器@tag要求满足如下功能:
@tag
def render(text):
# 执行其他操作
return text
@tag
def render2():
return 'abc'
print(render('Hello')) # 打印出: <p>Hello</p>
print(render2()) # 打印出: <p>abc</p>
def tag(func):
def test(*args, **kwarg):
result = func(*args, **kwarg)
print(f'<p>{result}</p>')
return result
return test
- 求列表 nums 中绝对值最大的元素
例如:nums = [-23, 100, 89, -56, -234, 123], 最大值是:-234
nums = [-23, 100, 89, -56, -234, 123]
result = max(nums, key=lambda item: item ** 2 ^ 2)
print('最大值:', result)
- 已经两个列表A和B,用map函数创建一个字典,A中的元素是key,B中的元素是value
A = ['name', 'age', 'sex']
B = ['张三', 18, '女']
新字典: {'name': '张三', 'age': 18, 'sex': '女'}
A = ['name', 'age', 'sex']
B = ['张三', 18, '女']
result111 = set(map(lambda item1, item2: eval(str(f'"{item1}:{item2}"')), A, B))
print('新字典:', result111)
- 已经三个列表分别表示5个学生的姓名、学科和班号,使用map将这个三个列表拼成一个表示每个学生班级信息的的字典
names = ['小明', '小花', '小红', '老王']
nums = ['1906', '1807', '2001', '2004']
subjects = ['python', 'h5', 'java', 'python']
结果:{'小明': 'python1906', '小花': 'h51807', '小红': 'java2001', '老王': 'python2004'}
names = ['小明', '小花', '小红', '老王']
nums = ['1906', '1807', '2001', '2004']
subjects = ['python', 'h5', 'java', 'python']
result111 = set(map(lambda item1, item2, item3: eval(str(f'"{item2+item3}:{item1}"')), names, nums, subjects))
print('新字典:', result111)
- 已经一个列表message, 使用reduce计算列表中所有数字的和(用采用列表推导式和不采用列表推导式两种方法做)
message = ['你好', 20, '30', 5, 6.89, 'hello']
结果:31.89
result = reduce(lambda x, y: x + y, list(x for x in message if type(x) == int or type(x) == float), 0)
def fun1(list1):
list2 = []
for x in list1:
if type(x) in (int, float):
list2.append(x)
return list2
result = reduce(lambda x, y: x + y, fun1(message), 0)