cari

Rumah  >  Soal Jawab  >  teks badan

Python新手问题——大txt文件按条件将多行合并

数据格式如下:
······
1107 1385331000000 1.3142511607126754
1107 1385331000000 0.0021683196661660157
1107 1385331600000 0.0021683196661660157
1107 1385331600000 1.4867805985670923
1107 1385331600000 0.0021683196661660157
1107 1385332200000 1.1697626938303243
1107 1385332800000 0.0021683196661660157
1107 1385332800000 0.005813069022279304
1107 1385332800000 1.2847329440609827
1107 1385332800000 0.0021683196661660157
1107 1385333400000 1.2891586380834603
1108 1385247600000 0.026943168177151356
1108 1385247600000 6.184696475262653
1108 1385248200000 0.05946288920050806
1108 1385248200000 6.359572785335356
1108 1385248200000 0.010602880590260044
1108 1385248800000 0.026943168177151356
1108 1385248800000 5.568047923787272
1108 1385249400000 0 0.01024202685104009
1108 1385249400000 5.213017822855314
1108 1385250000000 0.01024202685104009
1108 1385250000000 5.385327254217893
1108 1385250600000 0.016259860511678353
1108 1385250600000 4.902644074658115
1108 1385251200000 4.141288808488436
1108 1385251800000 0.05388633635430271
1108 1385251800000 4.684096694966861
1108 1385251800000 0.01024202685104009
1108 1385252400000 4.386580113177049
1108 1385253000000 4.582219390797833
1108 1385253600000 5.211061096279831
1108 1385254200000 0.02048405370208018
1108 1385254200000 3.901546051563316
1108 1385254200000 0.01024202685104009
1108 1385254800000 4.0387888693118255
······
每一行数据间是tab键隔开的
第一列是标号,第二列是UTC格式时间戳,第三列是流量数据,每行的数据是10分钟内的,现在想把同一个标号的比如第一列为1107的每一小时的数据叠加起来成为新的一行(第二列的时间可以用时间戳表示或者以时间间隔表示),完全没有头绪,请大神指点指点

迷茫迷茫2820 hari yang lalu678

membalas semua(8)saya akan balas

  • 黄舟

    黄舟2017-04-18 10:36:26

    Saya menyelesaikannya sendiri Walaupun ia mungkin rumit, ia boleh memenuhi keperluan

    __author__ = 'Administrator'
    file = open('day24.txt', 'a+')
    s = "area       time            data\n"
    file.write(s)
    file.close
    
    
    file = open('sms-call-internet-mi-2013-11-24-24.txt','r')
    line = file.readline()
    list1 = []#时间
    num1 = []#data
    area = []
    
    while 1:
        line = file.readline()
        if line == '':
            break
        a = line.split()
        if int(a[0]) == 1:
            if a[2] == "NA":
                a[2] = '0'
            area.append(a[0])
            if a[1] in list1:
                num1[list1.index(a[1])] = float(num1[list1.index(a[1])])+float(a[2])
            else:
                list1.append(a[1])
                num1.append(a[2])
        elif int(a[0]) < 10001:
    
            if a[2] == "NA":
                a[2] = '0'
            if a[0] not in area:
                area.append(a[0])
    
                file1 = open('day24.txt', 'a+')
    
                for i in list1:
                    file1.write("%-8s%-16s%.20f\n" % (area[area.index(a[0])-1], i, float(num1[list1.index(i)])))
                file1.close
                file1 = open('day24.txt', 'r')
                file1.close
                list1 = []
                num1 = []
    
            if a[1] in list1:
                num1[list1.index(a[1])] = float(num1[list1.index(a[1])])+float(a[2])
    
            else:
                list1.append(a[1])
                num1.append(a[2])
        else:
            break
    file.close
    
    file = open('day24.txt', 'a+')
    for j in list1: 
        file.write("%-8s%-16s%.20f\n" % (a[0], j, float(num1[list1.index(j)])))
    file.close
    file = open('day24.txt', 'r')
    file.close
    

    balas
    0
  • ringa_lee

    ringa_lee2017-04-18 10:36:26

    Jika ia berdasarkan siri masa, hanya gunakan penjana untuk membaca fail asal, menjana baris baharu dan kemudian mengeluarkannya.

    balas
    0
  • ringa_lee

    ringa_lee2017-04-18 10:36:26

    panda boleh menyelesaikan keperluan anda, membaca data ke dalam bingkai data dan kemudian memprosesnya

    balas
    0
  • 怪我咯

    怪我咯2017-04-18 10:36:26

    Ini bergantung pada jumlah data yang anda ada

    1. Gunakan traversal pemegang fail, jangan gunakan readlines() (memori mungkin tidak mencukupi)

    2. Gunakan struktur data yang serupa dengan kamus untuk menyimpan maklumat anda Jika memori tidak mencukupi, anda perlu mencari cara untuk menulis maklumat perantaraan ke cakera, dsb.

    Idea umum adalah seperti berikut

    from collections import Counter
    c = Counter()
    f = ['1107 1385332800000 1.2847329440609827',
    '1107 1385332800000 0.0021683196661660157',
    '1107 1385333400000 1.2891586380834603',
    '1108 1385247600000 0.026943168177151356',
    '1108 1385247600000 6.184696475262653',
    '1108 1385248200000 0.05946288920050806' ]
    
    '''
    with open('xxoo.txt') as f:  # f 文件遍历句柄,相当于上面的 list f
        for i in f:
            s = i.split()
            c[s[0]] += s[2]
    '''
    
    
    for i in f:  # 这里是遍历 f, 这里遍历的是 list f, 你实际情况要用上面的 f
        s = i.split()  # 这里是空格分割,可以使用 print s 看看结果
        c[s[0]] += float(s[2])  # c 用来统计
    
    for i in c:
        print i, c[i]

    balas
    0
  • PHPz

    PHPz2017-04-18 10:36:26

    Apa yang anda lakukan ialah mengumpulkan statistik berdasarkan dua penunjuk: label dan jam Gunakan panda untuk membaca masuk, gunakan to_datetime untuk menukar cap masa kepada lajur masa dan kemudian dapatkan bilangan jam kemudian gunakan groupby untuk mengklasifikasikan label dan jam pada masa yang sama, dan jumlahnya.

    balas
    0
  • 黄舟

    黄舟2017-04-18 10:36:26

    Sila gunakan idea ini
    https://www.zhihu.com/questio...

    balas
    0
  • 阿神

    阿神2017-04-18 10:36:26

    Saya rasa format data anda boleh dianalisis sedikit sebelum melakukannya
    1 Lajur pertama mewakili tarikh, anda boleh menggunakannya sebagai kunci peringkat pertama tatasusunan hasil, keputusan[tarikh]<🎜. >2. Lajur kedua mestilah cap masa (minit), jadi jika anda memerlukan hasil mengikut jam, anda memulakan 24 elemen untuk setiap item [data] hasil, dan kuncinya ialah bilangan jam (anda boleh menggunakan bilangan jam yang sepadan) Nilai setem digunakan sebagai kunci), dan nilai kunci sepadan dengan jumlah data dalam jam ini, iaitu, tarikh keputusan
    3 Selepas memulakan tatasusunan hasil, ia adalah mudah . Anda hanya melintasi fail dan memprosesnya baris demi baris Setiap baris Mula-mula baca nilai lajur pertama, seperti 1107,
    kemudian kendalikan hasil[1107]. Kemudian baca lajur kedua, cari kunci cap jam yang sepadan dan tambahkan sahaja.
    4 Akhir sekali, lalui tatasusunan hasil dan keluarkan hasilnya.

    balas
    0
  • 天蓬老师

    天蓬老师2017-04-18 10:36:26

    Anda memerlukan:

    from itertools import groupby

    Ia boleh dilakukan dalam kurang daripada sepuluh baris kod.

    balas
    0
  • Batalbalas