草庐IT

some_dict

全部标签

python - 什么时候可以设置 dict_values View (为什么)?

文档说valuesviewsarenottreatedasset-like,但有时它们是:>>>d={1:1}>>>d.values()|d.keys(){1}>>>d.values()&d.keys(){1}>>>d.values()-d.keys()set()为什么实现集合返回集合语义但随后以实际集合失败?>>>d.values()-{1}TypeError:unsupportedoperandtype(s)for-:'dict_values'and'set' 最佳答案 这实际上不是dict_values处理操作。keys_vi

python - python dict str() 函数是否可靠地对键进行排序?

在python中,字典{1:1,2:2,3:3}和{3:3,2:2,1:1}产生"{1:1,2:2,3:3}"当str()'d?我能否依赖这种排序,或者至少依赖于包含相同键/值对的字典在通过str()函数时会生成相同的字符串这一事实? 最佳答案 您不能依赖这两个属性中的任何一个。字典转换为字符串时的顺序还取决于键/值对的插入顺序。只要对Python源代码有一点了解(观看PyCon2010中的TheMightyDictionary),或者通过反复试验,您可以轻松找到反例:>>>{1:1,9:9}{1:1,9:9}>>>{9:9,1:1

python - 'str' 对象没有属性 '__dict__'

我想在Python中将字典序列化为JSON。我有这个'str'objecthasnoattribute'dict'错误。这是我的代码...fromdjango.utilsimportsimplejsonclassPerson(object):a=""person1=Person()person1.a="111"person2=Person()person2.a="222"list={}list["first"]=person1list["second"]=person2s=simplejson.dumps([p.__dict__forpinlist])异常(exception)情况是;

python - 在python dict中获取对应于max(value)的Key(s)

这个问题在这里已经有了答案:Gettingkeywithmaximumvalueindictionary?(29个答案)关闭9年前。让我们考虑以下(键,值)对的示例字典:dict1={'a':10,'x':44,'f':34,'h':89,'j':90,'d':28,'g':90}dict2={'a':10,'x':44,'f':34,'h':89,'j':90,'d':28}在字典中的所有值中,90是最高的。我需要检索与之对应的一个或多个key。完成这项工作的可能方法有哪些?哪个最有效,为什么?注意:字典中的键和/或值顺序不对。该程序不断向字典中添加新的(键、值)对。max(valu

python - 当你调用 `if key in dict` 时会发生什么

我有一个实现了__hash__和__eq__的类(我们称它为myClass)。我还有一个dict将myClass对象映射到某个值,计算需要一些时间。在我的程序中,许多(数以百万计)myClass对象被实例化。这就是我使用dict来跟踪这些值的原因。但是,有时新的myClass对象可能等同于旧的对象(由__eq__方法定义)。因此,与其再次计算该对象的值,不如在dict中查找旧的myClass对象的值。为此,我执行ifmyNewMyClassObjindict。这是我的问题:当我使用in子句时,调用的是什么,__hash__或__eq__?使用dict的要点是它的查找时间为O(1)。那么

Python:在字典中组合 "if ' x' 和 "for i in dict[' x']"

真的有两个问题:如果我有一个字典(最初来自解析json消息),其中有一个可选数组:dict_with={'name':'bob','city':'sanfrancisco','kids':{'name':'alice'}}dict_without={'name':'bob','city':'sanfrancisco'}我通常会有这样的代码:if'kids'indict:forkindict['kids']:#dostuff我的第一个问题是有什么python方法可以结合if保护和for循环吗?第二个问题是我的直觉告诉我原始json消息的更好设计是始终指定kids元素,只是使用一个空字典:

python - Pandas to_dict 使用 outtype ='records' 更改索引类型

我正在尝试在以下DataFrame上调用to_dict函数:将pandas导入为pddata={"a":[1,2,3,4,5],"b":[90,80,40,60,30]}df=pd.DataFrame(数据)ab01901280234034604530df.reset_index().to_dict("r")[{'a':1,'b':90,'index':0},{'a':2,'b':80,'index':1},{'a':3,'b':40,'index':2},{'a':4,'b':60,'index':3},{'a':5,'b':30,'index':4}]但是,如果我对数据帧执行浮点运

python - 如何访问 Python 父类(super class)的属性,例如通过 __class__.__dict__?

如何获取python类的所有属性名称包括那些从父类(superclass)继承的属性?classA(object):defgetX(self):return"X"x=property(getX)a=A()a.x'X'classB(A):y=10b=B()b.x'X'a.__class__.__dict__.items()[('__module__','__main__'),('getX',),('__dict__',),('x',),('__weakref__',),('__doc__',None)]b.__class__.__dict__.items()[('y',10),('__m

python - dict.keys() 和 dict.values() 保证什么顺序?

这个问题在这里已经有了答案:Pythondictionary:arekeys()andvalues()alwaysthesameorder?(9个回答)关闭5年前。Thisquestionarisesfromthisanswerwhereoneuserusesd.keys()andd.values()separatelytoinitialiseadataframe.众所周知,python3.6以下版本的字典是无序的。考虑以下形式的通用字典:d={k1:v1,k2:v2,k3:v3}其中键k*是任何可哈希对象,值v*是任何对象。当然不能保证顺序,但是d.keys()和d.values()

python - 为什么 dict_items 对象不支持索引?

我知道您可以将dict_items转换为list以允许项目索引。但是不知道为什么直接不允许这个操作。是因为dict_items对象是生成器吗?如果是这样,当我看到>>>{"foo":"bar","baz":"qux"}.items()dict_items([('foo','bar'),('baz','qux')])当repr被调用时,Python是否评估我的生成器? 最佳答案 dict_items不支持索引,因为这些对象旨在类似于集合,而集合不支持索引。它们以其他方式像集合一样嘎嘎作响:>>>d1={'k1':'v1','k2':'