Кажется, это работает:
for tag in soup2.findAll("meta"):
if tag.get("property", None) == "og:description":
print(tag.get("content", None))
По сути, вы перебираете все теги на странице и ищете те, для которых свойство имеет значение «og: description», которое выглядит как Откройте свойство Graph, которое вы хотите.
Помогает ли это?
Полная версия:
from bs4 import BeautifulSoup
import requests
url = "https://www.instagram.com/p/BsOGulcndj-/"
page2 = requests.get(url)
soup2 = BeautifulSoup(page2.content, 'html.parser')
result = soup2.findAll('meta', attrs={'content': 'description'})
for tag in soup2.findAll("meta"):
if tag.get("property", None) == "og:description":
print(tag.get("content", None))
Обновление : Что касается вашего вопроса о красивой печати, есть несколько способов, которые могут быть выполнены , Один из таких способов включает регулярные выражения и интерполяцию строк. Например:
likes = re.search('(.*)Likes', string).group(1)
comments = re.search(',(.*)Comments', string).group(1)
description = re.search('-(.*)', string).group(1)
print(f"{likes} Likes | {comments} Comments | {description}")
Но если у вас есть еще один вопрос по этому поводу, вероятно, это должно быть сделано в новом посте.
Вы, кажется, используете классические классы старого стиля в python 2. Для свойства для работы правильно необходимо использовать модернизированные классы вместо этого (в python 2, который Вы должны наследовать от object
). Просто объявите свой класс как MyClass(object)
:
class testDec(object):
@property
def x(self):
print 'called getter'
return self._x
@x.setter
def x(self, value):
print 'called setter'
self._x = value
Это работает:
>>> k = testDec()
>>> k.x
called getter
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/devel/class_test.py", line 6, in x
return self._x
AttributeError: 'testDec' object has no attribute '_x'
>>> k.x = 5
called setter
>>> k.x
called getter
5
>>>
Другая деталь, которая могла бы вызвать проблемы, - то, что для обоих методов нужно то же название свойства для работы. при определении метода set с другим именем как это, он не будет работать :
@x.setter
def x_setter(self, value):
...
И еще одна вещь, которую не абсолютно легко определить сначала, порядок: метод get должен быть определен сначала . При определении метода set сначала Вы добираетесь name 'x' is not defined
ошибка.
Необходимо использовать модернизированные классы, которые Вы делаете путем получения класса из объекта:
class testDec(object):
....
Тогда это должно работать.