У меня есть входной текстовый файл, например:
Input.txt-
1=88|2=1438|3=KKK|4=7.7|5=00|7=66|8=a
1=13|2=1388|3=DDD|4=157.73|6=00|7=08|8=b|9=k
Я хочу разделить эти пары ключ и значение и показать в таком формате:
Output.txt-
index[0]
1 88
2 1438
3 kkk
4 7.7
5 00
6
7 66
8 a
9
index[1]
1 13
2 1438
3 DDD
4 157.73
5
6 00
7 08
8 b
9 k
см. В индексе [0] значения 6 и 9-й записи являются пустыми, потому что 6 доступно в другом столбце, но не в этом. Так, в индексе [1] пятая запись пуста.
Программный код-
df = pd.read_csv(inputfile, index_col=None, names=['text'])
#spliting two times with respect to (= & |) and saving into stack
s = df.text.str.split('|', expand=True).stack().str.split('=', expand=True)
#giving index's as empty string ('') i.e. for removing
s.columns = ['idx','']
#rename_axis(None) for excluding index values
dfs = [g.set_index('idx').rename_axis(None) for i, g in s.groupby(level=0)]
#length for iterating through list
dfs_length = len(dfs)
#opening output file
with open(outputfile + 'output.txt','w') as file_obj:
i = 0
while i < dfs_length:
#index of each column
s = '\nindex[%d]\n'%i
#writing index to file
file_obj.write(str(s))
#print '\nindex[%d]'%i
#print dfs[i]
#wriring actual contents to file
file_obj.write(str(dfs[i])+'\n')
i = i + 1
Я получаю такой результат:
output.txt-
index[0]
1 88
2 1438
3 kkk
4 7.7
5 00
7 66
8 a
index[1]
1 13
2 1438
3 DDD
4 157.73
6 00
7 08
8 b
9 k
Я получаю только те записи, которые доступны во входных текстовых файлах. Как я могу сохранить значение записи как пустое?
9=...
)? - person MaxU   schedule 14.07.2016