Вот что я получил: (Отредактировано после ответа.)
import re
File1 = open('text.txt', 'r')
regex = re.compile(r'\b(?:[12]?\d{1,4}|30{4})#[^#]+#')
string = File1.read()
itemdesc = regex.findall(string)
for word in itemdesc:
print (word)
Используя: \ b (?: [12]? \ D {1,4} | 30 {4}) # [^ #] + # я смог найти:
5173#bunch of text here
of, bunch here, text
text here, bunch of
#
Найдя этот текст, я хотел бы заменить его в другом файле, где есть похожий.
На текущем этапе мне еще нужно реализовать что-то вроде:
\b(?:number)#[^#]+#
Чтобы найти текст, переместите и замените его в другом файле, где находится текст с таким же номером, также перед выполнением этого проверьте, есть ли несколько вхождений.
После этого у меня возникнет другая проблема, заключающаяся в сохранении нескольких вхождений и сохранении их в другом тексте, чтобы вручную сделать все остальное.
Надеюсь, вы, ребята, можете помочь, любая помощь приветствуется, это не должно быть решением. :)
Проблема здесь в том, что вы читаете файл и сопоставляете регулярное выражение строка за строкой, когда вы действительно хотите сопоставить регулярное выражение по нескольким строкам. Поэтому вы должны прочитать весь файл в одной строке, прежде чем сопоставить ее с регулярным выражением:
import re
File1 = open('text.txt', 'r')
regex = re.compile(r'\b(?:[12]?\d{1,4}|30{4})#[^#]+#')
string = File1.read()
itemdesc = regex.findall(string)
for word in itemdesc:
print (word)
Спасибо, я явно не знаком с python, ваш ответ очень помог.