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')
Другие вопросы по тегам