我有一个相当大的(1000页)结构化文本列表,我想将其转换为数据框架(最好使用R,但我对建议持开放态度)。
文本文件如下所示:
AC-Acrelândia
TV Canal 18 AINDA NÃO OUTORGADO
RTV Canal 9 RADIO TV DO AMAZONAS LTDA
RTV Canal 10 RADIO TV DO AMAZONAS LTDA(REDENCAO)
TVD Canal 15 RADIO TV DO AMAZONAS LTDA
TVD Canal 15 AINDA NÃO OUTORGADO(REDENÇÃO)
FM 88,5 MHz RADIO E TV MAIRA LTDA
AC-Assis Brasil
TV Canal 34 AINDA NÃO OUTORGADO
RTV Canal 6 AMAZONIA CABO LTDA
RTV Canal 10 RADIO TV DO AMAZONAS LTDA
RTV Canal 13 AINDA NÃO OUTORGADO
RTV Canal 45 FUNDACAO JOAO PAULO II我想把它转换成这样的东西:
AC Acrelândia TV Canal 18 AINDA NÃO OUTORGADO
AC Acrelândia RTV Canal 9 RADIO TV DO AMAZONAS LTDA
AC Acrelândia RTV Canal 10 RADIO TV DO AMAZONAS LTDA(REDENCAO)
....看起来readLines()是一个很好的开始,但是我在使用它的结构时遇到了困难。
发布于 2012-06-03 14:23:47
至CSV文件
由于您对其他语言持开放态度,因此我建议使用Python作为解决方案。它会生成一个csv文件,如下所示:
"AC","Acrelândia","TV","Canal 18","AINDA NÃO OUTORGADO"
"AC","Acrelândia","RTV","Canal 9","RADIO TV DO AMAZONAS LTDA"
"AC","Acrelândia","RTV","Canal 10","RADIO TV DO AMAZONAS LTDA(REDENCAO)"
"AC","Acrelândia","TVD","Canal 15","RADIO TV DO AMAZONAS LTDA"
"AC","Acrelândia","TVD","Canal 15","AINDA NÃO OUTORGADO(REDENÇÃO)"
"AC","Acrelândia","FM","88,5 MHz","RADIO E TV MAIRA LTDA"
"AC","Assis Brasil","TV","Canal 34","AINDA NÃO OUTORGADO"
"AC","Assis Brasil","RTV","Canal 6","AMAZONIA CABO LTDA"
"AC","Assis Brasil","RTV","Canal 10","RADIO TV DO AMAZONAS LTDA"
"AC","Assis Brasil","RTV","Canal 13","AINDA NÃO OUTORGADO"
"AC","Assis Brasil","RTV","Canal 45","FUNDACAO JOAO PAULO II"《守则》
这做了两个假设:(1)文件中的第一行或空行后面的任何行都是站点名称;(2)字段由两个或多个空格分隔
#-*- coding: utf-8 -*-
import re
import csv
# CREATE DATA STRUCTURE TO SIMULATE READING A TEXT FILE
data = u'''AC-Acrelândia
TV Canal 18 AINDA NÃO OUTORGADO
RTV Canal 9 RADIO TV DO AMAZONAS LTDA
RTV Canal 10 RADIO TV DO AMAZONAS LTDA(REDENCAO)
TVD Canal 15 RADIO TV DO AMAZONAS LTDA
TVD Canal 15 AINDA NÃO OUTORGADO(REDENÇÃO)
FM 88,5 MHz RADIO E TV MAIRA LTDA
AC-Assis Brasil
TV Canal 34 AINDA NÃO OUTORGADO
RTV Canal 6 AMAZONIA CABO LTDA
RTV Canal 10 RADIO TV DO AMAZONAS LTDA
RTV Canal 13 AINDA NÃO OUTORGADO
RTV Canal 45 FUNDACAO JOAO PAULO II'''.split('\n')
def read_records():
for line in data:
yield line
# INITIALIZE SPLITTER, READ RECORDS AND WRITE TO CSV FILE
splitter = re.compile('\s{2,}')
change_station = True
station = ''
f = open('./output.csv', 'w')
writer = csv.writer(f, quoting=csv.QUOTE_ALL)
for rec in read_records():
rec = rec.strip()
if rec == '':
change_station = True
elif change_station == True:
station = rec.replace('-', ' ')
change_station = False
else:
record = station + ' ' + rec
record = record.encode('utf-8')
record = re.split(splitter, record)
writer.writerow(record)
f.close()
# READ IN FILE AND PRINT TO CONSOLE FOR DEMO PURPOSES
f = open('./output.csv', 'r')
print ''.join( f.readlines() )
f.close()发布于 2012-06-03 14:43:56
如果你喜欢使用Python,那么这将会起作用(假设制表符分隔的输出):
import os
program = open('program', 'r')
new_prog = open('new_prog', 'w')
# Get initial state and city
state, city = program.readline().rstrip().split('-')
for line in program:
# Blank lines denote city change
if not line.strip():
line = program.next()
state, city = line.rstrip().split('-')
line = program.next()
band, cname, channel, show = line.rstrip().split(None, 3)
new_line = '\t'.join([state, city, band, cname, channel, show, os.linesep])
new_prog.write(new_line)
program.close()
new_prog.close()https://stackoverflow.com/questions/10867952
复制相似问题