关于《Head First Python》一书中print_lol()函数的思考

时间:2023-03-08 22:16:23

关于《Head First Python》一书中print_lol()函数的思考

  在《Head First Python》第一章中,讲述到Python处理复杂数据(以电影数据列表为例),首先将电影数据创建为Python列表,由于Python的变量标识符没有类型,列表中的每一个数据项可以是任何类型的数据,甚至可以是另外一个列表,并且可以无限嵌套。下面开始print()和print_lol()的表演。

  关于《Head First Python》一书中print_lol()函数的思考

   列表  movies = ["The Holy Grail", 1975, "Terry Jones & Terry Gilliam", 91,

               ["Graham Chapman",

                   ["Michael Palin", "John Cleese", "Terry Gilliam", "Eric Idle", "Terry Jones"]]]

step1(使用数据偏移量进行列表内数据的精准查找):

  

 print(movies[4][1][3])  
输出结果为:

关于《Head First Python》一书中print_lol()函数的思考

step2(使用一层print()对整个列表进行输出):

  

 print(movies)

输出结果为:

关于《Head First Python》一书中print_lol()函数的思考

step3(使用print()加上一层for循环对整个列表进行输出):

  

   for i in movies:
  print(i) 输出结果为:

关于《Head First Python》一书中print_lol()函数的思考


step4(使用print()加上两层for循环加上一个if else对整个列表进行输出):

  

 for i in movies:
if isinstance(i,list):
for j in i:
print(j)
else:
print(i)
输出结果为:

关于《Head First Python》一书中print_lol()函数的思考

step5(使用print()加上三层for循环加上两个if else对整个列表进行输出):

  

 for i in movies:
if isinstance(i,list):
for j in i:
if isinstance(j,list):
for k in j:
print(k)
else:
print(j)
else:
print(i)
输出结果为:

关于《Head First Python》一书中print_lol()函数的思考

step6(多层嵌套实在是太麻烦了,试试构造函数然后递归,祭出今天的重场戏print_lol()):

 首先定义函数:
def print_lol(the_list):
for i in the_list:
if isinstance(i,list):
print_lol(i)
else:
print(i) 然后使用print_lol()来对movies列表进行输出,即print_lol(movies)
输出结果为:

关于《Head First Python》一书中print_lol()函数的思考

  

  今天加班太晚了,有点累了,那么就将关于print_lol()函数不断趋于完善的过程的思考放在明天的博客中,要努力奋斗,同时晚安好梦。