from __future__ import absolute_import import re from typing import Dict, Text from .base import BaseParser class OpenGraphParser(BaseParser): def extract_data(self): # type: () -> Dict[str, Text] meta = self._soup.findAll('meta') content = {} for tag in meta: if tag.has_attr('property') and 'og:' in tag['property']: content[re.sub('og:', '', tag['property'])] = tag['content'] return content