机器学习第12章FP-growth算法:

bigL = [v[0] for v in sorted(headerTable.items(), key=lambda p:p[1])]

 在python3中会报错:TypeError: unorderable types: treeNode() < treeNode()

原因:首先查看p[1]内容:

    for i in headerTable.items():
        print(i[1])
    print('********************************')

 输出:

[3, <__main__.treeNode object at 0x000002030A0FC518>]
[3, <__main__.treeNode object at 0x000002030A0FC630>]
[4, <__main__.treeNode object at 0x000002030A0FC240>]
[3, <__main__.treeNode object at 0x000002030A0FC048>]
[5, <__main__.treeNode object at 0x000002030A0FC128>]
[3, <__main__.treeNode object at 0x000002030A0FC588>]

 默认比较第一列元素,但是当第一列元素相等时会比较第二列元素,而第二列元素是treeNode类型,无法比较treeNode类型的数据。

解决方法:

方法1、将p[1]转换成str类型

bigL = [v[0] for v in sorted(headerTable.items(), key=lambda p:str(p[1]))]

 方法2、将p[1]改成p[1][0],明确指定比较的元素是第一列,如果相等则按照原有顺序排列。

 

相关文章:

  • 2022-12-23
  • 2021-05-13
  • 2021-06-20
  • 2022-01-15
  • 2022-12-23
  • 2021-07-11
猜你喜欢
  • 2021-12-26
  • 2021-07-25
  • 2021-12-27
  • 2021-09-09
  • 2021-07-29
  • 2021-08-16
  • 2021-10-02
相关资源
相似解决方案