#python #regex
#python #регулярное выражение
Вопрос:
У меня есть список журналов Apache, которые я хочу просмотреть и разделить каждый элемент на новый список.
Например
83.149.9.216 - - [17/May/2015:10:05:03 0000] "GET /presentations/logstash-monitorama-2013/images/kibana-search.png HTTP/1.1" 200 203023 "http://semicomplete.com/presentations/logstash-monitorama-2013/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/32.0.1700.77 Safari/537.36"
Однако в одной из записей нет конечных кавычек для последнего элемента (User agent)
46.118.127.106 - - [20/May/2015:12:05:17 0000] "GET /scripts/grok-py-test/configlib.py HTTP/1.1" 200 235 "-" "Mozilla/5.0 (compatible; Googlebot/2.1; http://www.google.com/bot.html
В настоящее время я использую это регулярное выражение,
apacheTup = re.match('([(d.)] ) (.*) (.*) [(.*?)] "(.*?)" (d ) (.*?) "(.*?)" "(.*?)"',fileStr).groups()
Однако я получаю сообщение об ошибке
Объект ‘NoneType’ не имеет атрибута ‘groups’
ошибка возникает в строке без кавычки в конце. Как мне изменить мое регулярное выражение, чтобы оно принимало пользовательский агент с заключительной кавычкой или без нее?
Ответ №1:
Вы могли бы добавить завершающую двойную кавычку, когда ее нет.
fileStr = '' if fileStr.endswith('"') else '"'
apacheTup = re.match( ....