1.现有字典 d= {‘a’:24,‘g’:52,‘i’:12,‘k’:33}请按value值进行排序?
d= {'a':24,'g':52,'i':12,'k':33}
sort_dict=sorted(d.items(),key=lambda x:x[1])
print(sort_dict)
这样的排序操作返回的是一个列表形式,有待调整。
[(‘i’, 12), (‘a’, 24), (‘k’, 33), (‘g’, 52)]
2.字典推导式
d = {key:value for (key,value) in iterable}
3.反转字符串 “aStr”?
aStr='123sdfFASF1212'
print(aStr[::-1])
4.请按alist中元素的age由大到小排序
def sort_by_age(list1):
return sorted(alist,key=lambda x:x['age'],reverse=True)
if __name__ == '__main__':
alist = [{'name': 'a', 'age': 20}, {'name': 'b', 'age': 30}, {'name': 'c', 'age': 25}]
print(sort_by_age(alist))
5.写一个列表生成式,产生一个公差为11的等差数列
print([x*11 for x in range(10)])
[0, 11, 22, 33, 44, 55, 66, 77, 88, 99]
6.下面代码的输出结果将是什么?
list = ['a','b','c','d','e']
print(list[10:])
[]
代码将输出[],不会产生IndexError错误,尝试用超出成员的个数的index来获取某个列表的成员。例如,尝试获取list[10]和之后的成员,会导致IndexError。然而,尝试获取列表的切片,开始的index超过了成员个数不会产生IndexError,而是仅仅返回一个空列表。因为运行的时候没有错误产生,导致Bug很难被追踪到。
7.给定两个列表,怎么找出他们相同的元素和不同的元素?
list1 = [1,2,3,5,6,7,8,9]
list2 = [3,4,5,12,3,5,5,6,8,9,10]
set1 = set(list1)
set2 = set(list2)
print(set1 & set2)
print(set1 ^ set2)
{3, 5, 6, 8, 9}
{1, 2, 4, 7, 10, 12}
最后输出的是一个集合类型,如果还想要输出为列表,可以list(set1 & set2)
8.python代码如何实现删除list里面的重复元素尼?
方法1:先用set()结合去重,然后转换成列表
l1 = ['b','c','d','c','a','a']
l2 = list(set(l1))
print(l2)
[‘d’, ‘b’, ‘a’, ‘c’]
方法2:循环遍历,再创建一个新的列表,并向里面添加元素。
l1 = ['b','c','d','c','a','a']
l2 = []
for i in l1:
if not i in l2:
l2.append(i)
print(l2)
方法3:
l1 = ['b','c','d','c','a','a']
l2 = sorted(set(l1),key=l1.index)
print(l2)
9.求出列表所有奇数并构造新列表
a = [1,2,3,4,5,6,7,8,9,10]
res = [ i for i in a if i%2==1]
print(res)
[1, 3, 5, 7, 9]
10.用一行python代码写出1+2+3+10248
from functools import reduce
#1.使用sum内置求和函数
num = sum([1,2,3,10248])
print(num)
#2.reduce 函数
num1 = reduce(lambda x,y :x+y,[1,2,3,10248])
print(num1)
学习转载:https://github.com/kenwoodjw/python_interview_question#