Python中数据类型的操作

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#

猜你喜欢

转载自blog.csdn.net/weixin_38819889/article/details/92091347
今日推荐