关于python的defaultdict

原文地址:http://www.cnblogs.com/herbert/archive/2013/01/09/2852843.html

作者首先看了看defaultdict的help解释,作者看了解释并且把英文翻译出来后,发现还是看不懂。

后面直接通过看示例看明白的。发现作者是挺风趣幽默的。

下面贴出,defaultdict() , setdefault和普通的 {} 代码

defaultdict和setdefault相比较,defaultdict的效率会高一些。

而普通的{}只能做赋值操作(因为你直接append操作的话你会找不到key)

import collections
s = [(‘yellow‘, 1), (‘blue‘, 2), (‘yellow‘, 3), (‘blue‘, 4), (‘red‘, 1)]

# defaultdict
d = collections.defaultdict(list)
for k, v in s:
    d[k].append(v)
# d结果为{‘blue‘: [2, 4], ‘red‘: [1], ‘yellow‘: [1, 3]
# Use dict and setdefault
g = {}
for k, v in s:
    g.setdefault(k, []).append(v)

# g结果为{‘blue‘: [2, 4], ‘red‘: [1], ‘yellow‘: [1, 3]}

# Use dict
e = {}
for k, v in s:
    e[k] = v# e结果为 {‘blue‘: 4, ‘red‘: 1, ‘yellow‘: 3}
时间: 2024-09-30 04:16:52

关于python的defaultdict的相关文章

Python collections.defaultdict

Python collections.defaultdict 笔记 其实defaultdict 就是一个字典,只不过python自动的为它的键赋了一个初始值.这也就是说,你不显示的为字典的键赋初值python不会报错,看下实际例子. 比如你想计算频率 frequencies = {} for word in wordlist: frequencies[word] += 1 python会抛出一个KeyError 异常,因为字典索引之前必须初始化,可以用下面的方法解决 for word in wo

Python collections.defaultdict() 与 dict的使用和区别

在Python里面有一个模块collections,解释是数据类型容器模块.这里面有一个collections.defaultdict()经常被用到.主要说说这个东西. 综述: 这里的defaultdict(function_factory)构建的是一个类似dictionary的对象,其中keys的值,自行确定赋值,但是values的类型,是function_factory的类实例,而且具有默认值.比如default(int)则创建一个类似dictionary对象,里面任何的values都是in

Python collections.defaultdict 笔记

其实defaultdict 就是一个字典,只不过python自动的为它的键赋了一个初始值.这也就是说,你不显示的为字典的键赋初值python不会报错,看下实际例子. 比如你想计算频率 frequencies = {} for word in wordlist: frequencies[word] += 1 python会抛出一个KeyError 异常,因为字典索引之前必须初始化,可以用下面的方法解决 for word in wordlist: try: frequencies[word] +=

python中defaultdict方法的使用

默认值可以很方便 众所周知,在Python中如果访问字典中不存在的键,会引发KeyError异常(JavaScript中如果对象中不存在某个属性,则返回undefined).但是有时候,字典中的每个键都存在默认值是非常方便的.例如下面的例子: strings = ('puppy', 'kitten', 'puppy', 'puppy', 'weasel', 'puppy', 'kitten', 'puppy') counts = {} for kw in strings: counts[kw]

python的defaultdict

defaultdict是dict的一个子类,接受一个工厂函数作为参数,当访问defaultdict中不存在的key时,会将工厂函数的返回值作为默认的value. class defaultdict(dict): """ defaultdict(default_factory[, ...]) --> dict with default factory The default factory is called without arguments to produce a

python:学习defaultdict,namedtuple

# -*- coding: utf-8 -*-__author__ = 'Administrator'import bisect#排序说明:http://en.wikipedia.org/wiki/insertion_sort#简化一些操作#1:删减外部调用,降低工作负载"""说明:程序复杂度的另一部分是调用其他函数,方法和类所引入的,一般来说,应该尽量将代码放在循环之外,对于嵌套的循环这点更加重要,不要在一个循环中反复计算可以在循环开始之前计算数值,内循环应该保持简洁.&q

python中defaultdict类

回宿舍前翻翻Codeforces的时候发现了一个有趣的代码..其实是我没这么用过 :D 这是一份417B的代码 1 import sys 2 from collections import defaultdict 3 4 n = int(sys.stdin.readline()) 5 d = defaultdict(lambda:-1) 6 for i in range(0, n): 7 x, k = map(int, sys.stdin.readline().split()) 8 z = d[

如何像Python高手(Pythonista)一样编程

最近在网上看到一篇介绍Pythonic编程的文章:Code Like a Pythonista: Idiomatic Python,其实作者在2006的PyCon会议后就写了这篇文章,写这篇文章的主要原因是作者发现很多有经验的Pythoner写出的代码不够Pythonic.我觉得这篇文章很不错,所以将它用中文写了下来(不是逐字的翻译,中间加了一些自己的理解),分享给大家.另:由于本人平时时间有限,这篇文章翻译了比较长的时间,如果你发现了什么不对的地方,欢迎指出.. 一.Python之禅(The

[转]如何像Python高手(Pythonista)一样编程

本文转自:http://xianglong.me/article/how-to-code-like-a-pythonista-idiomatic-python 最近在网上看到一篇介绍Pythonic编程的文章:Code Like a Pythonista: Idiomatic Python,其实作者在2006的PyCon会议后就写了这篇文章,写这篇文章的主要原因是作者发现很多有经验的Pythoner写出的代码不够Pythonic.我觉得这篇文章很不错,所以将它用中文写了下来(不是逐字的翻译,中间