Вопрос

Допустим, я анализирую файл, который использует ; в качестве символа комментария.Я не хочу анализировать комментарии.Итак, если строка выглядит так:

example.com.              600     IN      MX      8 s1b9.example.net ; hello!

Есть ли более простой/более элегантный способ удалить символы, кроме этого:

rtr = ''
for line in file:
    trig = False
    for char in line:
        if not trig and char != ';':
            rtr += char
        else:
            trig = True
    if rtr[max(rtr)] != '\n':
        rtr += '\n'
Это было полезно?

Решение

Я бы рекомендовал сказать

line.split(";")[0]

который даст вам ряд всех символов, но не будет включать в себя первое «»; характер.Если нет ";" Персонаж присутствует, тогда он даст вам всю строку.

Другие советы

Просто сделайте разделение на линии по комментарию, а затем получите первый элемент, например,

line.split(";")[0]

Для Python 2.5 или более поздней версии я бы использовал partition метод:

rtr = line.partition(';')[0].rstrip() + '\n'
file = open(r'c:\temp\test.txt', 'r')
for line in file:   print
   line.split(";")[0].strip()

Итак, вам нужно разделить строку по первой точке с запятой, взять все, что перед ней, удалить все оставшиеся пробелы и добавить символ новой строки.

rtr = line.split(";", 1)[0].rstrip() + '\n'

Ссылки на документацию:

Чтение, разделение, удаление и объединение строк с символом новой строки в одной строке Python:

rtr = '\n'.join(line.split(';')[0].strip() for line in open(r'c:\temp\test.txt', 'r'))

Вот еще один способ:

In [6]: line = "foo;bar"
In [7]: line[:line.find(";")] + "\n"
Out[7]: 'foo\n'

Я не тестировал это с помощью Python, но я использую аналогичный код еще где-то.

import re
content = open(r'c:\temp\test.txt', 'r').read()
content = re.sub(";.+", "\n")
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top