Python - удалить последний символ в файле списка соединений
Я создаю файл списка соединений из файла csv, как вы можете видеть ниже, и я пытаюсь подавить последний символ "," текста этого файла после его создания, но я не могу
module Filtre(E[0],E[1],E[2],E[3],S[0],S[1],S[2],S[3],);
Ожидаемый результат:
module Filtre(E[0],E[1],E[2],E[3],S[0],S[1],S[2],S[3]);
Моя функция для создания файла списка соединений:
fichNet = open('Netlist.v', 'r+')
def readColCSV(fichier):
with open(fichier, 'r') as read_obj:
csv_dict_reader = DictReader(read_obj)
entete = csv_dict_reader.fieldnames[0]
fichNet.writelines('\nmodule {}('.format(entete))
for row in csv_dict_reader:
if 'E' in row['pin name'] or 'S' in row['pin name']:
fichNet.writelines('{},'.format(row['pin name']))
fichNet.writelines(');\n\n')
2 ответа
Решение
Он будет работать, создаст пустой список, добавит ваши строки в список и соединится с "," так что он не будет писать "," в конце вашей строки.
fichNet = open('Netlist.v', 'r+')
def readColCSV(fichier):
with open(fichier, 'r') as read_obj:
csv_dict_reader = DictReader(read_obj)
entete = csv_dict_reader.fieldnames[0]
fichNet.writelines('\nmodule {}('.format(entete))
#Add here
l=[]
for row in csv_dict_reader:
if 'E' in row['pin name'] or 'S' in row['pin name']:
#Change here
l+=[row['pin name']]
#Change here
fichNet.writelines(','.join(l)+');\n\n')
Измените свою функцию на это:
fichNet = open('Netlist.v', 'r+')
def readColCSV(fichier):
with open(fichier, 'r') as read_obj:
csv_dict_reader = DictReader(read_obj)
entete = csv_dict_reader.fieldnames[0]
fichNet.writelines('\nmodule {}('.format(entete))
for row in csv_dict_reader:
if 'E' in row['pin name'] or 'S' in row['pin name']:
if csv_dict_reader.index(row) != csv_dict_reader[-1]:
fichNet.writelines('{},'.format(row['pin name']))
else:
fichNet.writelines('{}'.format(row['pin name']))
fichNet.writelines(');\n\n')