来自Java背景,我知道这__str__
类似于toString的Python版本(虽然我确实意识到Python是较老的语言)。
因此,我定义了一个小类以及一个__str__
如下的方法:
class Node:
def __init__(self, id):
self.id = id
self.neighbours = []
self.distance = 0
def __str__(self):
return str(self.id)
然后,我创建它的一些实例:
uno = Node(1)
due = Node(2)
tri = Node(3)
qua = Node(4)
现在,尝试打印这些对象之一时的预期行为是将打印其关联的值。这也会发生。
print uno
产量
1
但是当我执行以下操作时:
uno.neighbours.append([[due, 4], [tri, 5]])
接着
print uno.neighbours
我懂了
[[[<__main__.Node instance at 0x00000000023A6C48>, 4], [<__main__.Node instance at 0x00000000023A6D08>, 5]]]
我期望的地方
[[2, 4], [3, 5]]
我想念什么?而我在做什么其他值得冒犯的东西呢?:)
Python有两种不同的方式将对象转换为字符串:str()
和repr()
。打印对象使用str()
;
打印包含对象str()
的列表将用于列表本身,但会实现各个项目的list.__str__()
调用repr()
。
因此,您还应该覆盖__repr__()
。一个简单的
__repr__ = __str__
在课堂结束时,技巧将发挥作用。
问题内容: 我可以理解以下定义: 每个对象都有一个标识,一个类型和一个值。一旦创建了对象,其身份就永远不会改变。您可能会认为它是对象在内存中的地址。所述操作者比较两个对象的身份; 该函数返回一个表示其身份的整数。 我认为上面的定义在创建“某物”时起作用,例如: 但是我不理解: 我还没有创建任何东西。那么整数“ 1”如何具有ID?这是否意味着只要我在Python Shell中“提及” 1,便立即将其
我正在阅读一个示例代码,它将添加一个10像素宽的灰色框架,通过用lambda表达式调用它来替换图像边界上的像素: 我对 lambda 表达式感到困惑: > 要为图形添加框架,我认为" “我真的不明白?颜色。白:c”。第一,为什么它们在前一个括号之外?其次,问号(?)意思是? 提前感谢您的帮助。
我正在尝试提出一种解决方案,它涉及在连接操作之后应用一些逻辑,从多个中的中选择一个事件。这类似于reduce函数,但它只返回1个元素,而不是递增地返回。因此最终结果将是单个(,对,而不是一个 每个键保证只到达一次。 假设像上面这样的连接操作,它用4个生成了1个,成功地连接并收集在。现在,我想做的是,立即访问这些值,并执行一些逻辑以将正确匹配到一个。例如,对于上面的数据集,我需要(,和)。 将为每个
所以我一直在读Kafka的语义学,我对它的工作原理有点困惑。 我理解生产者如何避免发送重复的消息(以防代理的ack失败),但我不明白的是,在消费者处理消息但在提交偏移量之前崩溃的情况下,一次是如何工作的。Kafka不会在这种情况下重试吗?
问题内容: 我已经在eclipse中创建了一个项目,并添加了Maven依赖项。在Eclipse中,它表示我正在使用JRE 1.5。一切在Eclipse中都可以正常运行,例如,我可以运行测试。 当我尝试从终端运行时,出现以下错误。 …在-source 1.3中不支持泛型(使用-source 5或更高版本来启用泛型)… 看来,Maven认为我正在使用JRE 1.3,并且无法识别泛型或for-each循
问题内容: 在碰到此链接http://www.javacodegeeks.com/2013/01/java-thread-pool-example-using- executors-and-threadpoolexecutor 之后,这是我第一次为新项目使用Java线程池。 .html ,我对此更加困惑,这是页面中的代码, 在代码中,创建了一个固定大小的池并创建了10个工作线程,对吗? 线程池应该