чтение файла без новых строк в Python

В Python вызов

temp = open(filename,'r').readlines()

приводит к получению списка, в котором каждый элемент является строкой в файле. Это немного глупо, но все же: readlines() также записывает символ новой строки в каждый элемент, чего я не хочу.

Как я могу избежать этого?

Комментарии к вопросу (2)
Решение

Вы можете прочитать весь файл и разделить строки, используя str.splitlines:

temp = file.read().splitlines()

Или вы можете удалить новую строку вручную:

temp = [line[:-1] for line in file]

Примечание: это последнее решение работает только если файл заканчивается новой строкой, иначе последняя строка потеряет символ.

Это предположение верно в большинстве случаев (особенно для файлов, созданных текстовыми редакторами, которые часто делают добавление завершающей новой строки в любом случае).

Если вы хотите избежать этого, вы можете добавить новую строку в конец файла:

with open(the_file, 'r+') as f:
    f.seek(-1, 2)  # go at the end of the file
    if f.read(1) != '\n':
        # add missing newline if not already present
        f.write('\n')
        f.flush()
        f.seek(0)
    lines = [line[:-1] for line in f]

Или более простая альтернатива - зачеркнуть новую строку:

[line.rstrip('\n') for line in file]

Или даже, хотя это довольно нечитабельно:

[line[:-(line[-1] == '\n') or len(line)+1] for line in file]

Который использует тот факт, что возвращаемое значение or - это не булева величина, а объект, который был оценен как true или false.


Метод readlines фактически эквивалентен:

def readlines(self):
    lines = []
    for line in iter(self.readline, ''):
        lines.append(line)
    return lines

# or equivalently

def readlines(self):
    lines = []
    while True:
        line = self.readline()
        if not line:
            break
        lines.append(line)
    return lines

Поскольку readline() сохраняет новую строку, readlines() также сохраняет ее.

Примечание: для симметрии к readlines() метод writelines() не добавляет завершающие новые строки, поэтому f2.writelines(f.readlines()) производит точную копию f в f2.

Комментарии (7)
temp = open(filename,'r').read().split('\n')
Комментарии (10)

Я думаю, что это лучший вариант.

temp = [line.strip() for line in file.readlines()]
Комментарии (3)
temp = open(filename,'r').read().splitlines()
Комментарии (1)

другой пример:

Прочитав одну строку файла по времени. Удаление нежелательных символов с конца строки ул.rstrip(чарс)

with open(filename, 'r') as fileobj:
    for row in fileobj:
        print( row.rstrip('\n') )

см. также стр.прокладка([Чарси]) и пр..lstrip([символов])

(в Python >= 2.0)

Комментарии (0)

Попробуйте это:

u=open("url.txt","r")  
url=u.read().replace('\n','')  
print(url)  
Комментарии (1)
import csv

with open(filename) as f:
    csvreader = csv.reader(f)
    for line in csvreader:
         print(line[0])
Комментарии (1)

Чтобы удалить все начальные и конечные пробельные символы (по аналогии с Абага'ы ответ) -

temp = [line.strip() for line in open("filename")]

Чтобы удалить все конечные whitspaces включая символ новой строки -

temp = [line.rstrip() for line in open("filename")]

Если вы хотите просто удаляет замыкающий символ новой строки, а не пробелы -

temp = [line.rstrip('\r\n') for line in open("filename")]

С. П. Если вы находите это полезным, то, пожалуйста, проголосовать за него.

Комментарии (2)
my_file = open("first_file.txt", "r")
for line in my_file.readlines():
    if line[-1:] == "\n":
        print(line[:-1])
    else:
        print(line)
my_file.close() 
Комментарии (1)
def getText():
    file=open("ex1.txt","r");

    names=file.read().split("\n");
    for x,word in enumerate(names):
        if(len(word)>=20):
            return 0;
            print "length of ",word,"is over 20"
            break;
        if(x==20):
            return 0;
            break;
    else:
        return names;

def show(names):
    for word in names:
        len_set=len(set(word))
        print word," ",len_set

for i in range(1):

    names=getText();
    if(names!=0):
        show(names);
    else:
        break;
Комментарии (0)