python - 很难?第一列或第二列相同的行合并?
PHP中文网
PHP中文网 2017-04-18 09:05:43
0
2
347

某一行中的字母,如果有在其他行也出现,则将他们合并为一行。
例如

A B
C A
D C
E F
N G
C N

结果

A B C D N G
E F
PHP中文网
PHP中文网

认证0级讲师

répondre à tous(2)
巴扎黑

Ce n'est pas que c'est facile à tirer. Écrivez d'abord une version approximative (le code est moche et l'ordre est complètement ignoré XD), puis améliorez-la lentement :

char2id = {}
id2charset = {}

def getcharset(c):
    try:
        return id2charset[char2id[c]]
    except:
        return None

def newcharset(chars):
    newset = set(chars)
    return newset

def merge(charset1, charset2):
    if id(charset1)==id(charset2):
        return
    charset1 |= charset
    for c in charset2:
        char2id[c] = id(charset1)
    id2charset.pop(id(charset2))

with open('test2') as reader:
    for line in reader:
        chars = line.strip().split()
        newset = newcharset(chars)
        id2charset[id(newset)] =newset

        for c in chars:
            charset = getcharset(c)
            if charset:
                merge(newset, charset)
            else:
                char2id[c] = id(newset)

with open('report', 'w') as writer:
    for id, charset in id2charset.items():
        print(' '.join(charset), file=writer)

Informations test :

A B
C A
D C
E F
N G
C N
X Y
F P
P Q
X Z

Résultat :

P E Q F
X Y Z
B D C G N A

Il est recommandé que le script que vous vérifiez soit écrit comme ceci :

from collections import Counter

with open('report', 'r') as reader:
    ct = Counter()
    for line in reader:
        ct += Counter(line.strip().split())

for item, count in ct.most_common():
    if count <= 1:
        break
    print(item, count)

Questions auxquelles j'ai répondu : Python-QA

巴扎黑
#!/usr/bin/env python
# -*- coding: utf-8 -*-
result = {}
with open('5.1.txt', 'r') as f:
    alist = []
    blist = []
    lines = f.readlines()
    for line in lines:
        line1 = line.strip().split()

        for i in line1:
            blist.append(i)
            if i not in alist:
                alist.append(i)
    for a in alist:
        print a, blist.count(a)
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal