我有一个包含许多元素的列表,其中一些元素有它们自己的子列表。下面是一个示例列表(我的实际列表有超过100个元素!)公司名称:
data_all = [{u'heatindexm': u'-9999', u'windchillm': u'-999', u'wdire': u'ENE', u'wdird': u'70', u'windchilli': u'-999', u'hail': u'0', u'heatindexi': u'-9999', u'precipi': u'', u'thunder': u'0', u'pressurei': u'29.95', u'snow': u'0', u'pressurem': u'1014', u'fog': u'0', u'icon': u'', u'precipm': u'', u'conds': u'', u'tornado': u'0', u'hum': u'44', u'tempi': u'71', u'tempm': u'22', u'dewptm': u'12', u'rain': u'0', u'dewpti': u'54', u'date': {u'mday': u'01', u'hour': u'00', u'min': u'00', u'mon': u'07', u'pretty': u'12:00 AM BST on July 01, 2015', u'year': u'2015', u'tzname': u'Europe/London'}, u'visi': u'12', u'vism': u'19', u'utcdate': {u'mday': u'30', u'hour': u'23', u'min': u'00', u'mon': u'06', u'pretty': u'11:00 PM GMT on June 30, 2015', u'year': u'2015', u'tzname': u'UTC'}, u'wgusti': u'', u'metar': u'AAXX 30234 03772 45/69 /0710 10215 20120 30111 40140 58018 333 55300 20000', u'wgustm': u'', u'wspdi': u'11.5', u'wspdm': u'18.5'}, {u'heatindexm': u'-9999', u'windchillm': u'-999', u'wdire': u'East', u'wdird': u'90', u'windchilli': u'-999', u'hail': u'0', u'heatindexi': u'-9999', u'precipi': u'-9999.00', u'thunder': u'0', u'pressurei': u'29.95', u'snow': u'0', u'pressurem': u'1014', u'fog': u'0', u'icon': u'clear', u'precipm': u'-9999.00', u'conds': u'Clear', u'tornado': u'0', u'hum': u'56', u'tempi': u'69.8', u'tempm': u'21.0', u'dewptm': u'12.0', u'rain': u'0', u'dewpti': u'53.6', u'date': {u'mday': u'01', u'hour': u'00', u'min': u'20', u'mon': u'07', u'pretty': u'12:20 AM BST on July 01, 2015', u'year': u'2015', u'tzname': u'Europe/London'}, u'visi': u'-9999.0', u'vism': u'-9999.0', u'utcdate': {u'mday': u'30', u'hour': u'23', u'min': u'20', u'mon': u'06', u'pretty': u'11:20 PM GMT on June 30, 2015', u'year': u'2015', u'tzname': u'UTC'}, u'wgusti': u'-9999.0', u'metar': u'METAR EGLL 302320Z 09008KT CAVOK 21/12 Q1014 NOSIG', u'wgustm': u'-9999.0', u'wspdi': u'9.2', u'wspdm': u'14.8'}]
我想迭代列表并从每个元素中提取某些信息(例如['pressurem']和['tempm']),但也要以这种方式从元素的子列表中提取信息,比如['utcdate']['hour']和['utcdate']['min'],这样每次迭代的输出都会被放入一个新的列表中。这些新列表将依次(作为元素)放置在宏列表中。在
我知道如何手动获取我想要的信息/值,也就是说,我可以为每个元素提取感兴趣的值,如下面的代码所示。此代码返回我感兴趣的值(包括子列表中的信息),这些值是我从data_all列表中的第一个元素中找到的。在
^{pr2}$但是,上面的方法只适用于列表的第一个元素,我无法为for循环找到正确的语法,for循环将遍历data_all list的每个元素,并为data_all list中的每个元素生成相同的输出。可以捕获data_all列表中每个元素的输出,并将其放入一个新列表中。。。。。。我希望上面的内容不要太混乱;基本上,我尝试用如下方式使用for循环(或类似的):
for i in data_all:
generate i number of data_strings
convert each data_string into a list
have each mini list as an element within a new list (list_of_elements)
print (list_of_elements) to show:
#1 [u'30', u'06', u'2015', u'23', u'00', u'22', u'44', u'1014']
#2 [u'11:20 PM GMT on June 30, 2015', u'21.0', u'56', u'1014']
#3 etc......
很抱歉这个新手的问题-可能有一个函数或库可以为我做以上的事情,但我只是在学习编码,所以我希望能够用正确的Python语法编写上面的内容。在
您已经显示此代码:
当您特别引用元素0时,请改用变量。您可以使用一个数字,例如:
^{pr2}$不过,更自然的做法是让循环为您处理索引:
要收集列表中的每一项,请列出一个列表并附加数据:
相关问题 更多 >
编程相关推荐