Получить номер строки определенной фразы в файле Python

мне нужно получить номер строки в текстовом файле. Фраза может быть:

the dog barked

мне нужно открыть файл, найти в нем эту фразу и распечатать номер строки.

Я использую Python 2.6 в Windows XP


Вот Что У Меня Есть:

o = open("C:/file.txt")
j = o.read()
if "the dog barked" in j:
     print "Found It"
else:
     print "Couldn't Find It"

это не домашнее задание, это часть проекта, над которыми я работаю. Я даже не знаю, как узнать номер телефона.

8 ответов


lookup = 'the dog barked'

with open(filename) as myFile:
    for num, line in enumerate(myFile, 1):
        if lookup in line:
            print 'found at line:', num

f = open('some_file.txt','r')
line_num = 0
search_phrase = "the dog barked"
for line in f.readlines():
    line_num += 1
    if line.find(search_phrase) >= 0:
        print line_num

EDIT 1.5 лет спустя (после того, как он получил еще один upvote): я оставляю это как есть; но если бы я писал сегодня, написал бы что-то ближе к решению Ash/suzanshakya:

def line_num_for_phrase_in_file(phrase='the dog barked', filename='file.txt')
    with open(filename,'r') as f:
        for (i, line) in enumerate(f):
            if phrase in line:
                return i
    return -1
  • используя with открыть файлы-это идиома pythonic - она гарантирует, что файл будет правильно закрыт, когда блок с помощью файла заканчивается.
  • итерация через файл с помощью for line in f намного лучше, чем for line in f.readlines(). Первый является pythonic (например, будет работать если f является любым общим iterable; не обязательно файловый объект, который реализует readlines), и более эффективным!--7--> создает список со всем файлом в памяти, а затем перебирает его. * if search_phrase in line - это более подходящие для Python, чем if line.find(search_phrase) >= 0, так как это не требует line для реализации find, читает более легко, чтобы увидеть, что предназначено, и не легко облажаться (например,if line.find(search_phrase) и if line.find(search_phrase) > 0 оба не будут работать для всех случаев, так как find возвращает индекс первого совпадения или -1).
  • его проще / чище обернуть повторяющийся элемент в enumerate как for i, line in enumerate(f) не удалось инициализировать line_num = 0 перед циклом, а затем вручную инкремент в цикле. (Хотя, возможно, это труднее читать для людей, незнакомых с enumerate.)

посмотреть код, как pythonista


def get_line_number(phrase, file_name):
    with open(file_name) as f:
        for i, line in enumerate(f, 1):
            if phrase in line:
                return i

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

lookup="The_String_You're_Searching"
file_name = open("file.txt")
for num, line in enumerate(file_name,1):
        if lookup in line:
            print(num)

откройте файл, а затем сделайте что-то вроде...

for line in f:
    nlines += 1
    if (line.find(phrase) >= 0):
        print "Its here.", nlines

существует множество способов чтения строк из файлов в Python, но for line in f техника более эффективна, чем большинство.


list = open("file_name","mode")

if "search element" in list:
    print list.index("search element")  # This will gives you the line number

for n,line in enumerate(open("file")):
    if "pattern" in line: print n+1

вот что я нашел работу:

f_rd = open(path, 'r')
file_lines = f_rd.readlines()
f_rd.close()

matches = [line for line in file_lines if "chars of Interest" in line]
index = file_lines.index(matches[0])