Python count 2变量if uniqu

2024-07-05 14:44:12 发布

您现在位置:Python中文网/ 问答频道 /正文

如果2个变量是唯一的,则代码必须对它们进行计数。
但我不能让它工作。
有人知道我怎样才能让它工作吗?你知道吗

我希望输出为:

C603 100nF 8

下面是.txt文件的一个简单示例。
踢脚板1.2版_组件列表.txt你知道吗

C1                      1nF            C0603                 rcl                                    (24.7 35.9)           R270
C2                      100nF          C0603                 rcl                                    (36.7 32.7)           R180
C3                      10uF_Tantalum  C0603                 rcl                                    (22.7 6.45)           R0
C4                      22uF           C0603                 rcl                                    (25 8.25)             R90
C5                      1uF            C0603                 rcl                                    (22.6 21.85)          R180

代码:

from operator import itemgetter
from collections import Counter

elements = []

elements.append([])
elements.append([])
elements.append([])

with open('C:\\Python\\Artinis\\BaseBoard_V1.2_Componentslist.txt') as f:
    for i in xrange(10):
        f.next()
    for line in f:
        list = line.split();
        elements[0].append(list[0])
        elements[1].append(list[1])
        elements[2].append(list[2])

for value, package in sorted(zip(elements[1], elements[2])):
    input = value, package
    c = Counter( input )
    print ( c.items() )

输出:

[('0.22uF', 1), ('C0603', 1)]
[('100', 1), ('R0603', 1)]
[('100', 1), ('R0603', 1)]
[('100', 1), ('R0603', 1)]
[('100', 1), ('R0603', 1)]
[('C0603', 1), ('100nF', 1)]
[('C0603', 1), ('100nF', 1)]
[('C0603', 1), ('100nF', 1)]
[('C0603', 1), ('100nF', 1)]
[('C0603', 1), ('100nF', 1)]
[('C0603', 1), ('100nF', 1)]
[('C0603', 1), ('100nF', 1)]
[('C0603', 1), ('100nF', 1)]
[('10K', 1), ('R0603', 1)]
[('10K', 1), ('R0603', 1)]
[('10k', 1), ('R0603', 1)]
[('10uF_Tantalum', 1), ('C0603', 1)]
[('R0603', 1), ('19.6K', 1)]
[('1nF', 1), ('C0603', 1)]
[('C0603', 1), ('1uF', 1)]
[('2.2uF', 1), ('C0603', 1)]
[('2.2uF', 1), ('C0603', 1)]
[('R0603', 1), ('22K', 1)]
[('R0603', 1), ('22K', 1)]
[('22uF', 1), ('C0603', 1)]
[('R0603', 1), ('483', 1)]
[('53047-05', 2)]
[('ATMEGA32L-8MU', 1), ('QFN50P700X700X100-45N', 1)]

我试着在谷歌上搜索,我试过其他代码,但对我不起作用。 有人知道怎么解决这个问题吗?你知道吗


Tags: 代码infromimporttxtforelementslist
2条回答

如果要将第二个和第三个元素中的每个元素计算为仅拆分的单个元素,请使用itertools.islice提取第二个和第三个元素,并调用islice对象上的tuple,使用生成器表达式将其传递给Counter:

from collections import Counter
from itertools import islice

with open('test.txt') as f:
    print(Counter(tuple(islice(line.split(), 1, 3)) for line in f))

示例的输出:

Counter({('10uF_Tantalum', 'C0603'): 1, ('22uF', 'C0603'): 1, ('1nF', 'C0603'): 1, ('100nF', 'C0603'): 1, ('1uF', 'C0603'): 1})

如果你想要更好的输出使用str.format格式并迭代:

with open('test.txt') as f:
    cn = Counter(tuple(islice(line.split(), 1, 3)) for line in f)
    for k, v in cn.items():
        print("{} {} {v}".format(*k, v=v))

输出:

10uF_Tantalum C0603 1
22uF C0603 1
1nF C0603 1
100nF C0603 1
1uF C0603 

前提是我们已经以这种方式组织了数据:

elements = [
    ("a", "b"),
    ("c", "d"),
    ("a", "b"),
    ("c", "d"),
    ("a", "b"),
]

我们可以创建一组独特的元素:

elset = set(elements)

然后显示每个唯一元素在原始列表中出现的次数:

for e in elset:
    print e[0], e[1], elements.count(e)

相关问题 更多 >