Как использовать регулярное выражение для поиска элементов с двойными кавычками или без них?

#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( ....