回答此问题可获得 20 贡献值,回答如果被采纳可获得 50 分。
<p>我有一个如下列表:</p>
<blockquote>
<p>[['1', ' H ', ' Hydrogen', ' 1.00794(4)', 'FFFFFF', '1s1 ', '2.2', '37', '', '120', '1312', '-73', '-1, 1', 'gas', 'diatomic', '14', '20', '0.0000899', 'nonmetal', '1766'], ['2', ' He ', ' Helium', ' 4.002602(2)', 'D9FFFF', '1s2 ', '', '32', '', '140', '2372', '0', '', 'gas', 'atomic', '', '4', '0.0001785', 'noble gas', '1868'], etc...]</p>
</blockquote>
<p>这一直贯穿元素周期表。我还有一个函数(在类中,因此是self),它应该打印一个子列表(每个元素一个子列表),如下所示:</p>
<pre><code>def get_element_data(self, identifier):
if type(identifier) == int:
if self.check_atomic_number_exists(identifier):
return self.parsed_data[identifier - 1]
if type(identifier) == str:
if len(identifier) <= 2:
print("passed in symbol")
return (element for element in self.parsed_data if identifier ==
element[1])
if len(identifier) > 2:
print("passed in name")
return (element for element in self.parsed_data if identifier ==
element[2])
parsing_object.get_element_data("Hydrogen")
</code></pre>
<p>但如果我运行它,它将返回一个生成器对象,而不是子列表。如何使其返回子列表?而且,如果我按原子序数搜索,效果也不错</p>