所以我基本上有一个非常大的具有相似名称的元素列表(c0、d0、c1、d1...等)
我想知道是否有一种更简单的方法可以生成一个脚本来使用字符串生成这些元素中的每一个
这会将字符串“c0”更改为实际变量 c0
出于与我的项目相关的原因,我希望避免使用列表,而宁愿生成代码
谢谢大家!
最佳答案
首先,请不要误会,但根据您问题中的代码,我假设您是 Python 新手:它不是有效的 Python。到处都有大量很棒的 Python 教程——阅读 Python 函数、内置函数和一般原理。这是一种非常强大的语言,但看起来您继承的脚本是......不是很 Pythonic。确保不要从中学到关于语言的错误东西。
因此,理想情况下,您希望所有这些变量都收集在某种数据结构中。 Python 有很多不同的类型。
如果您需要做的只是比较一对固定数据集中的每个索引,则可以使用元组:这些是有序的、不可变的集合,暗示了一些结构。假设您有 n 对数据:您有两个元组,我们称它们为 c 和 d,但使用描述性名称显然更好如果可以的话。它看起来像这样:
c = (c0, c1, c2, ... cn)
d = (d0, d1, d2, ... dn)
然后您会将它们与以下内容进行比较:
for i in range(len(c)):
if c[i] == d[i]:
print '%d: match' % i
else:
print '%d: no match' % i
(两个注意事项:len() 查找对象的长度,range() 创建一个可互换的序列——您的问题使用 len() 的地方,您想在 Python 中使用 range()。另外,% d 的东西只是字符串格式。)
我的假设是您需要做的不止于此。一方面,如果写这篇文章的人认为将数据存储为数百个唯一的全局变量是个好主意,我不会假设他想在运行时做一些事情,比如确保每个变量都存在并保存数据等所以在这种情况下我个人会使用字典,因为它给了你更多的灵 active 。
每个字典都是键值对的集合。 Dicts 是无序的,所以你不能直接比较每个中的第一项——没有第一项。您可以做的是使用一个整数序列作为键,然后遍历该序列的范围。你可以做一些事情,比如用默认值检索一个值,这样如果 c64 从未被声明,你就不会崩溃程序:
c = {0:'a', 1:'b', 2:'c', 3:'d', 4:'r'}
d = {0:'a', 1:'B', 2:None, 3:'d'}
然后是这样的:
for i in range(len(c)):
if c.get(i, 'No value') == d.get(i, 'No value'):
print '%d: match' % i
else:
print '%d: no match' % i
虽然您通常会从像 c[4]
或 d['apple']
这样的字典中检索数据。 Get() 允许我们使用默认值(“无值”)以防 i 的某些值丢失。
(另一个假设:每对数据代表某种真实的数据关系,因此迭代次数在语义上既是索引又是标签。在我看来,键通常应该是标签而不是值本身。 )
您在评论中提出的将现有变量收集到其中一个结构中的建议可以正常工作。只需打开 Notepad++ 并使用您的源代码进行一些智能搜索/替换,这将花费您十分钟的时间。你最终会得到 c = (c0, c1, c2, etc)
或 c = {0:c0, 1:c1, etc}
,或者如果您会找到适合您需要的另一种结构。但我真正认为您应该做的是重构整个脚本,以便您比较的数据存储在某种对象中,该对象反射(reflect)了它是什么以及您如何使用它。 Python 将让您在这里发挥真正的魔力:通过一些跑腿工作,您可以做一些像 c == d
这样简单的事情,找到 c 的联合或不相交集和 d,在某些迭代中或任何您需要的时候操纵数据值。
关于python - 我正在寻找一种在 python 中生成代码的简单方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15375009/