- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
<分区>
有很多不错的类似getattr()的函数用于解析嵌套的字典结构,例如:
我想做一个并行的 setattr()。本质上,给定:
cmd = 'f[0].a'
val = 'whatever'
x = {"a":"stuff"}
我想生成一个可以分配的函数:
x['f'][0]['a'] = val
或多或少,这将以与以下相同的方式工作:
setattr(x,'f[0].a',val)
产生:
>>> x
{"a":"stuff","f":[{"a":"whatever"}]}
我目前称它为 setByDot()
:
setByDot(x,'f[0].a',val)
这样做的一个问题是,如果中间的键不存在,则需要检查并创建一个中间键(如果它不存在)---即,对于上述内容:
>>> x = {"a":"stuff"}
>>> x['f'][0]['a'] = val
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
KeyError: 'f'
因此,您首先必须:
>>> x['f']=[{}]
>>> x
{'a': 'stuff', 'f': [{}]}
>>> x['f'][0]['a']=val
>>> x
{'a': 'stuff', 'f': [{'a': 'whatever'}]}
另一个是下一项是列表时的键控与下一项是字符串时的键控不同,即:
>>> x = {"a":"stuff"}
>>> x['f']=['']
>>> x['f'][0]['a']=val
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'str' object does not support item assignment
...失败,因为赋值是针对空字符串而不是空字典。空字典将是字典中每个非列表的正确赋值,直到最后一个——它可能是一个列表或一个值。
@TokenMacGuy 在下面的评论中指出的第二个问题是,当您必须创建一个不存在的列表时,您可能必须创建大量空白值。所以,
setattr(x,'f[10].a',val)
---可能意味着算法将不得不做一个像这样的中间体:
>>> x['f']=[{},{},{},{},{},{},{},{},{},{},{}]
>>> x['f'][10]['a']=val
屈服
>>> x
{"a":"stuff","f":[{},{},{},{},{},{},{},{},{},{},{"a":"whatever"}]}
这就是与 getter 关联的 setter...
>>> getByDot(x,"f[10].a")
"whatever"
更重要的是,中间体应该/不/覆盖已经存在的值。
以下是我迄今为止的一个垃圾想法——我可以识别列表与字典和其他数据类型,并在它们不存在的地方创建它们。但是,我看不到 (a) 将递归调用放在哪里,或者 (b) 当我遍历列表时如何“构建”深层对象,以及 (c) 如何区分/probing/我正在就像我从/setting/构造深层对象一样,当我到达堆栈的末尾时我必须做。
def setByDot(obj,ref,newval):
ref = ref.replace("[",".[")
cmd = ref.split('.')
numkeys = len(cmd)
count = 0
for c in cmd:
count = count+1
while count < numkeys:
if c.find("["):
idstart = c.find("[")
numend = c.find("]")
try:
deep = obj[int(idstart+1:numend-1)]
except:
obj[int(idstart+1:numend-1)] = []
deep = obj[int(idstart+1:numend-1)]
else:
try:
deep = obj[c]
except:
if obj[c] isinstance(dict):
obj[c] = {}
else:
obj[c] = ''
deep = obj[c]
setByDot(deep,c,newval)
这看起来非常棘手,因为如果你正在制作占位符,你必须向前看以检查/next/对象的类型,并且你必须向后看以在你前进时建立一条路径.
更新
我最近有 this question也回答了,这可能是相关的或有帮助的。
如果我使用 setattr(p,'wrong_attr','value') 而不是 p=MyModel.objects.filter(WRONG_ATTRIBUTE=value) 我没有收到与不存在的
我有一个定义了多个方法的类。 import mat class Klass(object): @mat.sell(mat.CanSet): def method1(self):
我不知所措。 找不到任何其他有助于解决此问题的内容。 dta = {'type': "", 'content': ""} print dta >>>{'content': '', 'type': ''
这就是我的意思: >>> class Foo: pass >>> foo = Foo() >>> setattr(foo, "@%#$%", 10) >>> foo.@%#$% Syn
这个问题已经有答案了: What do lambda function closures capture? (8 个回答) 已关闭 3 年前。 我正在尝试创建一个 class适应django反对导出。
我想了解对象删除在 python 上的工作原理。这是一组非常简单的代码。 class A(object): def __init__(self): setattr(self,
我有一个类(bot),它有一个属性“health”;由于这个类有很多参数,并且我希望用户输入很多参数,所以我选择循环遍历 {param:explanation} 的字典,并为每个参数输入一个要设置的值
我应该将什么作为第一个参数“object”传递给函数 setattr(object, name, value) , 在当前模块上设置变量? 例如: setattr(object, "SOME_CONS
我试图制作一个可以一次性将多个属性分配给不同值的类。因此,我尝试修改 setattr 来执行此操作。 class hello(): def __setattr__(self,attr,valu
我想使用 setattr 更改列的因子水平. However, when the column is selected the standard data.table方式( dt[ , col] ),
为什么在附加或连接对象属性的列表或字典时未调用 __setattr__ 方法。方法描述“在尝试属性分配时调用。”会让我相信连接两个列表是可行的,但是 __setattr__ 方法仍然没有被调用。 cl
我想以编程方式更改类的某些属性。 我发现有setattr函数,但它没有按预期工作。 > obj.setattr('bar', 99) 'MyClass' object has no attribute
我正在创建一个 sigsum() 函数,它使用输入方程和输入变量求和。这是我到目前为止所拥有的: def sigsum(eqn, index, lower=0, upper=None, step=1)
我在 cython 中有一个 cdef 类,我想用 setattr 内置函数初始化它的字段。但是,当我这样做时出现执行错误: /path/.../cimul.cpython-34m.so in cim
我有一个模型类,它有一个引用 django DB 对象的属性。我想使用带有 setattr() 的单个 View 来更改此属性,我用它来更改此对象的任何属性。 问题是,我似乎无法通过堆栈传递对象实例。
我想使用 setattr 创建绘图: import numpy as np import matplotlib.pyplot as plt x = np.random.rand
我试图动态地向类添加方法,但我一直遇到错误,其中 self 未传递给新函数。例如: class Dummy(): def say_hi(self): print("hi") d
我正在编写的一个类需要使用存储 numpy 数组的变量名属性。我想为这些数组的切片赋值。我一直在使用 setattr,这样我就可以让属性名称有所不同。我为切片赋值的尝试是: class Dummy(o
我对 python 还很陌生,但是我需要与一些作为一堆 python 模块编写的软件进行交互(.py 文件,以防我错误地将它们识别为“模块”。)这个程序有一些非常有用的功能以及我确实无法破解的复杂功能
class Product(models.Model): name = models.CharField(max_length=50) desc = models.CharFiel
我是一名优秀的程序员,十分优秀!