Я пытаюсь записать текстовый файл в файл csv, используя пакет csv в python, используя этот код:
import csv
with open(r'C:\Users\soso-\Desktop\SVM\DataSet\drug_list.txt') as f:
with open('integrated_x.csv', 'w') as out_file:
writer= csv.writer(out_file)
for line in f:
print(line.strip())
writer.writerow(line.strip())
введите здесь описание изображения
Я ожидал, что файл будет таким же, как в терминале, но я не знаю, почему он написан в файле csv так
как я могу это исправить данные отображаются в csv следующим образом:
D,B,0,0,6,3,2
D,B,0,0,4,3,3
D,B,0,1,1,9,4
D,B,0,0,2,7,3
D,B,0,2,5,3,0
Я хочу, чтобы файл csv был таким:
DB00632,
DB00433,
DB01194,
DB00273,
DB02530,
Является ли входной файл просто идентификатором препарата (например, «DB00632» и т. д.), каждый из которых находится в отдельной строке?
@CodeMonkey да, именно так выглядит текст
Добавьте пробел в качестве разделителя в write=csv.writer(out_file, delimiter=' ') это не пустая строка, а строка с одинарным пробелом -> '' не нравится''
Чтобы просто вывести название препарата с помощью "," не нужен csvwriter. Можно просто написать название препарата через ",", например. fout.write(f"{line.strip()},\n")
Я пробовал это, но это выглядит так DB 0 2 5 3 0 @MuhammadZeeshan
@SaraAlmashharawi попробовать без пробела? нравится -> ''
Ваш входной файл уже является совершенно правильным файлом CSV - нет необходимости в разделителях запятых, когда в каждой строке нужно разделить не более одной вещи. Почему вы вообще пытаетесь его преобразовать?
Непредвиденная ошибка, которую вы видите с выводом типа «D,B,0,0,6,3,2», связана с writer.writerow()
ожиданием списка или итерируемого аргумента. Затем строка DB00632 преобразуется в символы, и в выходных данных CSV каждая буква отделяется запятой без использования модуля записи CSV.
Если вы просто хотите добавить запятую (,) в конец каждого идентификатора лекарства, вы можете просто вывести название лекарства, за которым следует запятая и новая строка.
Обратите внимание, что в файле CSV еще нет строки заголовка, а во втором столбце ничего нет.
with open('drug_list.txt') as f:
with open('integrated_x.csv', 'w') as out_file:
for line in f:
line = line.strip()
print(line)
out_file.write(f"{line},\n")
Если ввод выглядит как идентификатор лекарства в каждой строке (например, DB00632), то вывод будет таким, как ожидалось:
DB00632,
DB00433,
DB01194,
DB00273,
DB02530,
Пожалуйста, переформатируйте код. При первоначальном осмотре кажется, что у вас есть несколько ошибочно поставленных двоеточий.