㈠ python 字典怎么转成两个列表,一个是key的,一个
在Python中,如果你希望将一个字典转换为两个列表,一个列表包含所有的键,另一个列表包含所有的值,你可以按照以下方式操作。假设你有一个字典a如下所示:
a = {1: 'a', 3: 'b', 5: 'c'}
通过调用字典的keys()和values()方法,你可以获取到字典的所有键和值。然后将这两个方法的结果分别赋值给两个变量,如b和c。
具体代码如下:
b, c = a.keys(), a.values()
这样,b将包含字典a中的所有键,而c将包含字典a中的所有值。需要注意的是,b和c将返回可迭代对象,如果你想将它们转换为列表,可以使用list()函数:
b = list(a.keys())
c = list(a.values())
这样,b和c将分别成为包含字典a键和值的列表。
在实际应用中,这种操作非常有用。例如,当你需要对字典中的键和值分别进行操作或排序时,将它们转换为列表后,可以更方便地进行处理。
此外,你还可以使用zip()函数将字典的键和值合并为一个列表的元组。具体操作如下:
keys_and_values = list(zip(a.keys(), a.values()))
这样,keys_and_values将是一个包含元组的列表,每个元组的第一个元素是字典的键,第二个元素是对应的值。
总之,将字典转换为键的列表和值的列表是一种常见的操作,它可以帮助你更好地处理字典中的数据。
㈡ Python中的常用内置函数有哪些呢
abs() divmod() input() open() staticmethod()
all() enumerate() int() ord() str()
any() eval() isinstance() pow() sum()
basestring() execfile() issubclass() print() super()
bin() file() iter() property() tuple()
bool() filter() len() range() type()
bytearray() float() list() raw_input() unichr()
callable() format() locals() rece() unicode()
chr() frozenset() long() reload() vars()
classmethod() getattr() map() repr() xrange()
cmp() globals() max() reverse() zip()
compile() hasattr() memoryview() round() __import__()
complex() hash() min() set()
delattr() help() next() setattr()
dict() hex() object() slice()
dir() id() oct() sorted()
㈢ python中for循环放在后面要怎么理解
i因为闭包,lambda生成之后i引用的就是for循环中的i
建议你看一下python的列表生成器,
f = [(lambda n : i + n) for i in range(10)] 等同于
f=[]
for i in range(10)
f.append(lambda n : i + n)
下面是相关内容
列表生成式即List Comprehensions,是Python内置的非常简单却强大的可以用来创建list的生成式。
举个例子,要生成list [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]可以用range(1, 11):
>>> range(1, 11)[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
但如果要生成[1x1, 2x2, 3x3, ..., 10x10]怎么做?方法一是循环:
>>> L = []>>> for x in range(1, 11):... L.append(x * x)
...>>> L
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
但是循环太繁琐,而列表生成式则可以用一行语句代替循环生成上面的list:
>>> [x * x for x in range(1, 11)]
[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
写列表生成式时,把要生成的元素x * x放到前面,后面跟for循环,就可以把list创建出来,十分有用,多写几次,很快就可以熟悉这种语法。
for循环后面还可以加上if判断,这样我们就可以筛选出仅偶数的平方:
>>> [x * x for x in range(1, 11) if x % 2 == 0]
[4, 16, 36, 64, 100]
还可以使用两层循环,可以生成全排列:
>>> [m + n for m in 'ABC' for n in 'XYZ']
['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']
三层和三层以上的循环就很少用到了。
运用列表生成式,可以写出非常简洁的代码。例如,列出当前目录下的所有文件和目录名,可以通过一行代码实现:
>>> import os # 导入os模块,模块的概念后面讲到>>> [d for d in os.listdir('.')] # os.listdir可以列出文件和目录['.emacs.d', '.ssh', '.Trash', 'Adlm', 'Applications', 'Desktop', 'Documents', 'Downloads', 'Library', 'Movies', 'Music', 'Pictures', 'Public', 'VirtualBox VMs', 'Workspace', 'XCode']
for循环其实可以同时使用两个甚至多个变量,比如dict的iteritems()可以同时迭代key和value:
>>> d = {'x': 'A', 'y': 'B', 'z': 'C' }>>> for k, v in d.iteritems():... print k, '=', v... y = B
x = A
z = C
因此,列表生成式也可以使用两个变量来生成list:
>>> d = {'x': 'A', 'y': 'B', 'z': 'C' }>>> [k + '=' + v for k, v in d.iteritems()]
['y=B', 'x=A', 'z=C']
最后把一个list中所有的字符串变成小写:
>>> L = ['Hello', 'World', 'IBM', 'Apple']>>> [s.lower() for s in L]
['hello', 'world', 'ibm', 'apple']
小结
运用列表生成式,可以快速生成list,可以通过一个list推导出另一个list,而代码却十分简洁。
思考:如果list中既包含字符串,又包含整数,由于非字符串类型没有lower()方法,所以列表生成式会报错:
>>> L = ['Hello', 'World', 18, 'Apple', None]
>>> [s.lower() for s in L]
Traceback (most recent call last):
File "<stdin>", line 1, in <mole>AttributeError: 'int' object has no attribute 'lower'
使用内建的isinstance函数可以判断一个变量是不是字符串:
>>> x = 'abc'>>> y = 123>>> isinstance(x, str)True>>> isinstance(y, str)False
请修改列表生成式,通过添加if语句保证列表生成式能正确地执行。