精华内容
下载资源
问答
  • 一种将列表用作字典键的相对安全,简单但高性能技术。
  • 我想使用如下字典:示例:{[8,16]:[[1,2,4,8],8],[16,24]:...使用setdefault,我可以在字典中创建值列表,但不能为创建列表以下是我代码:#!/usr/bin/env python"""This Program calculates common factors betw...

    我想使用如下字典:

    示例:{[8,16]:[[1,2,4,8],8],[16,24]:[[1,2,3,4,8,12],12]}

    8和16是将要输入的两个数字,我需要构建如上所述的字典.

    使用setdefault,我可以在字典中创建值列表,但不能为键创建列表

    以下是我的代码:

    #!/usr/bin/env python

    """

    This Program calculates common factors between two Numbers , which

    is stored on a list and also greatest common factor is also computed.

    All this is stored in a dictionary

    Example: { '[n1, n2]': [[Commonfac1(n1,n2), Commonfac2(n1,n2)....Commonfacn(n1,n2)],GreatestCommonFactor] }

    """

    def Factors(number):

    result = []

    for i in range(1, number+1):

    if (number % i) == 0:

    result.append(i)

    return result

    def Common_Factors(n1, n2):

    result = []

    for element in n1:

    if element in n2:

    result.append(element)

    return result

    def greatest_common_factor(common_factors):

    count = 0

    length = len(common_factors)

    current_largest = common_factors[count]

    for i in common_factors:

    count += 1

    if count <= length -1:

    if current_largest < common_factors[count]:

    current_largest = common_factors[count]

    return current_largest

    def main():

    n1 = 8

    n2 = 16

    result1 = Factors(n1)

    result2 = Factors(n2)

    CF = Common_Factors(result1, result2)

    GCF = greatest_common_factor(CF)

    dict = {}

    dict.setdefault([n1, n2], []).append(CF)

    print dict

    if __name__ == '__main__':

    main()

    当我运行上面的程序时,我得到以下错误:

    $python math74.py

    Traceback (most recent call last):

    File "math74.py", line 58, in

    main()

    File "math74.py", line 54, in main

    dict.setdefault([n1, n2], []).append(CF)

    TypeError: unhashable type: 'list'

    关于我如何实现上述任何提示. ?

    澄清更多:

    {[8,16]:[[1,2,4,8],8],[16,24]:[[1,2,3,4,8,12],12]}

    8,16是两个数字,它们是用户输入,1,2,4,8是常见因子,8是最大公因数.

    展开全文
  • 此外,列表理解似乎不工作:>>> parsed_results.keys() dict_keys(['Sounder V Depth, F', 'Vessel Latitude, Degrees-Minutes']) >>> things2plot = [key.split(', ') for key in parsed_results...

    此外,列表理解似乎不工作:

    >>> parsed_results.keys() dict_keys(['Sounder V Depth, F', 'Vessel Latitude, Degrees-Minutes']) >>> things2plot = [key.split(', ') for key in parsed_results.keys()] >>> things2plot ['Sounder V Depth', 'F'] >>> for key in parsed_results.keys(): ... print(key.split(', ')) ... ['Sounder V Depth', 'F'] ['Vessel Latitude', 'Degrees-Minutes']

    就我个人而言,我认为这是对鸭子打字的“违反”,因此是一个“错误”。 但是我认为现在还有其他人注意到了这一点,所以如果没有确定的话,就必须被认为是一个“特征”,但是我不能为了我的生活而明白为什么。

    对Chris的补充说明:

    好了,克里斯,那么至less应该更好的误用检测和通知(“你似乎不想要一个迭代器在这里,你是否期待一个列表?试试列表(dict.keys())…”)会更像我已经知道并喜爱的有用的Python。 :/(我要求你提供数据来支持你声明迭代器的function是dict.keys的“更常见”的用例,但是你可能会提供它。);-)到目前为止因为我的列表理解的例子不工作(对我来说),它是从PyCharmdebugging器命令行剪切和粘贴的,所以也许这个问题是一个错误。 (我今天已经遇到过另外一个“bug”了,所以根本不会让我感到吃惊。)谢谢!

    展开全文
  • 在python的字典的属性方法里面有一个has_key()方法,这个方法使用起来非常简单。 例: #生成一个字典 d = {'name':{},'age':{},'sex':{}} #打印返回值 print(d.has_key('name')) #结果返回True 实际上这种方法...

    第一种方法:使用自带函数实现。


    在python的字典的属性方法里面有一个has_key()方法,这个方法使用起来非常简单。

    例:
    
    #生成一个字典
    d = {'name':{},'age':{},'sex':{}}
    #打印返回值
    print(d.has_key('name'))
    #结果返回True


    实际上这种方法在python3中已经不适用,而被__contains(‘keyname’)所替代

    d.__contains__(“name”)


    第二种方法:使用in方法

    #生成一个字典
    d = {‘name’:{},‘age’:{},‘sex’:{}}
    #打印返回值,其中d.keys()是列出字典所有的key
    print(name in d.keys())
    #结果返回True

    但是都有这样的错误

    TypeError: unhashable type: ‘list’

    后来才发现了我是使用列表作为字典的键,所以才会有这样的错误。
    ————————————————
    版权声明:本文为CSDN博主「cook_1996」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/weixin_42156928/article/details/87858404

    展开全文
  • In Python 2.7, I could get dictionary keys, values, or items as a list:>>> newdict = {1:0, 2:0, 3:0}>>> newdict.keys()[1, 2, 3]Now, in Python >= 3.3, I get something like this:>...

    In Python 2.7, I could get dictionary keys, values, or items as a list:

    >>> newdict = {1:0, 2:0, 3:0}

    >>> newdict.keys()

    [1, 2, 3]

    Now, in Python >= 3.3, I get something like this:

    >>> newdict.keys()

    dict_keys([1, 2, 3])

    So, I have to do this to get a list:

    newlist = list()

    for i in newdict.keys():

    newlist.append(i)

    I'm wondering, is there a better way to return a list in Python 3?

    解决方案

    Try list(newdict.keys()).

    This will convert the dict_keys object to a list.

    On the other hand, you should ask yourself whether or not it matters. The Pythonic way to code is to assume duck typing (if it looks like a duck and it quacks like a duck, it's a duck). The dict_keys object will act like a list for most purposes. For instance:

    for key in newdict.keys():

    print(key)

    Obviously, insertion operators may not work, but that doesn't make much sense for a list of dictionary keys anyway.

    展开全文
  • 我想保存dataframe列名称和lists索引值,所以我想使用一个以lists值为和dataframe.loc[list_index]作为价值。[0,2,1,5,0,9,6,3]所以我想做一个这样决定:0: [column1, another column]1: [column3,...].......
  • 之后用 :clst_dic[keyName].append(str) 对字典中的一个键赋值时,所有的键都被赋了相同的值。很是气愤,当把列表改为其他类型时,如:clst_dic = {}.fromkeys(randomL, '') ,就不会出现是这个问题。所以猜测是
  • I have a python dictionaryd = {1: 6, 2: 1, 3: 1, 4: 9, 5: 9, 6: 1}Since the values in the above dictionary are not unique. I want to group the all the keys of unique values as a list and create a new ...
  • 数据库,dictdict,dictionary列表的dictionary,命名元组(它是一个子类),sqlite,冗余。。。我不相信我眼睛。还有什么?"It might well be that dictionaries with tuples as keys are not the proper way to ...
  • Python数据分析与数据可视化:包含列表的元组可以作为字典的”。【?????】A:对B:错Python数据分析与数据可视化章节测试答案:错更多相关问题2020年知到汽车理论(西安理工大学)2020年生物信息学中国大学MOOC2020年...
  • #将列表元素交替的作为键和值来创建字典 #方法一 def dictfromlist(keysandvalues): return dict(zip(keysandvalues[::2],keysandvalues[1::2])) lista =[1,2,3,4] print dictfromlist(list
  • 通常我们使用字典时候,总会遇到编程数据里三部曲,编写、访问、使用,而其中访问也算是一个比较重要内容了,一起来看下吧~访问值我们通过提供索引来访问列表值。类似地,在字典中,通过使用来访问值。...
  • 我发布了reduce()方法作为一种好奇,但是由于答案被接受,我发布了timeit结果,以便将性能与这张罚单上其他答案进行比较。在from timeit import timeitimport functoolsdef _reduce_py2(the_list):return reduce...
  • 为什么tuple可以作为字典的key,list不可以?要理解这个问题,首先要明白python的字典工作原理。Python的字典是如何工作的在Python中,字典也就是一个个的“映射”,将key映射到value:# 对一个特定的key可以得到一...
  • 我不得不将两个函数从测试中取出,因为它们必须有许多失败结果,而且它们不支持将列表或dict作为值返回,我认为这是必要,因为一个函数应该为几乎所有数据做好准备。所以我在100.000次迭代中通过timeit模块泵...
  • 集合对象是一组无序排列***可哈希***的值,集合成员可以做字典的键。那么可哈希与不可哈希是什么意思呢? 简要的说可哈希的数据类型,即不可变的数据结构(字符串str、元组tuple、对象集objects);同理,不可哈希的...
  • Python中字典的排序分为按“”排序和按“值”排序。下面话不多说了,来一起看看详细的介绍吧 问题描述 我们有一个字典列表,想根据一个或多个字典中的值来对列表排序。 例如,有如下字典列表,根据字典中的x,由...
  • 如何根据字典的键或值来排序

    万次阅读 2016-07-24 18:26:04
    字典的值可以是任何对象类型(字典甚至可以嵌入另一个字典中),键可以为任何可hash的对象,也就是它不可以被改变(所以字符串并不是唯一合法的键,但是可变的比如列表就绝对不能作为键)。不像Python的列表或者元组...
  • 时候,给定了一个列表,我们需要交替使用列表元素作为键和对应值来创建字典,比如下面一个列表 &gt;&gt;&gt; lst = ['Jerry', 20, 'Alice', 30, 'Wendy', 40] 我们需要将第一个作为键,第二...
  • 您可以使用itertools.groupby,首先对字典使用.items(),然后根据键的第一个元素对该列表进行排序,并使用键作为键的第一个元素(第一个元素第一个元素)使用itertools.groupby关键元组,值).然后,对于每个组,您可以对值...
  • 题目是设计一个字典,用户输入内容作为‘键’,然后输出字典中对应的‘值’如果输入的键不存在,则输出:输入的键不存在! 代码如下: #a = {‘name’:‘li’,‘age’:‘26’,‘gender’:‘male’} #一个列表,键与...
  • 我有一个列表的字典,数字作为,字符串列表作为值.例如.,my_dict = {1: ['bush', 'barck obama', 'general motors corporation'],2: ['george bush', 'obama'],3: ['general motors', 'george w. bush']}我想要是...
  • I have a list of strings parsed from somewhere, in the following format:[key1, value1, key2, value2, key3, value3, ...]I'd like to create a dictionary based on this list, like so:{key1:value1, key2:va...
  • 创建方法一:方法二:从Python 2.2 版本起,可以使用一个工厂方法,传入一个元素是列表的元组作为参数方法三:从Python 2.3 版本起, 可以用一个很方便内建方法fromkeys() 来创建一个"默认"字典, 字典中元素具有相同...
  • 不过要注意,这里的元素,是一对(key)和值(value)相比于列表和元组,字典的性能更优,特别是对于查找、添加和删除,字典都能在常数的时间复杂度内完成而集合和字典基本相同,唯一的区别,就是集合没有和值的配对...
  • 如何形成字典,将键作为字段名称,将值作为每行值 o/p: d = {'FAV_VENUE_CITY_NAME':['Mumbai','New Delhi','Bangalore'], 'EVENT_GENRE':['KIDS','FANTASY','FESTIVAL','WORKSHOP','EXHIBITION'], 'FAV_GENRE':['...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 816
精华内容 326
关键字:

列表作为字典的键