Peteryo01223 发表于 2020-1-2 15:19:11

关于《课后作业》的“活学活用”

小甲鱼《课后作业 012》的“活学活用”,正确答案如下:

list1 = ['1. Just do it', '2. 一切极有可能', '3. 让编程改变世界', '4. Impossible in Nothing']
list2 = ['4.阿迪达斯', '2.李宁', '3.鱼c工作室', '1.耐克']
list3 = for slogan in list1 for name in list2 if slogan == name]
for each in list3:
    print(each)

请问:
slogan == name 的表达,为什么会被 Python 准确地理解为 “序号相同”呢?程序run得很顺利,但我不理解。

slogan的意思是slogan这个数列中的第一个元素的意思?但是, '1. Just do it' 给我的感觉仅仅是一个单一元素,并不是一个数列。它怎么会被理解成为一个由 “1” 、“.” 和 “Just do it” 组成的一对数列呢?

同一个问题,slogan 的表达,也是因为Python 把 '1. Just do it' 看做一个由 “1” 、“.” 和 “Just do it” 组成的一对数列?因此仅仅显示 最后的一个元素,即:“Just do it”,不显示 “1. ”?

答案的意思我能看懂,但此处 编程语言的严谨性、唯一性,我没能理解。

请帮助解释。谢谢大神啦~

sunrise085 发表于 2020-1-2 15:26:53

list3 = for slogan in list1 for name in list2 if slogan == name]

这是一个迭代。slogan从list1中寻找,name从list2中寻找,若两个字符串的第一个字符一样( if slogan == name),则进行前面的拼接,即name + ':' + slogan
举例说明:
当name='1.耐克'时,slogan='1.just do it',此时list3中对应的元素由这个语句构成name+':'+slogan,即‘1.耐克’和':'和‘just do it’三个字符串拼接而成,也即‘1.耐克:just do it’,list3的其他元素类似。所以才会出现这个结果。

zltzlt 发表于 2020-1-2 18:45:43

索引不仅能用于序列,还能用于字符串。slogan 表示 slogan 的第一个元素,slogan 表示 slogan 的第三个字符串一直截取到最后。

例如:

假设 slogan = '12345',那么 slogan 为 '345',slogan 为 '1'。
页: [1]
查看完整版本: 关于《课后作业》的“活学活用”