- PVSM.RU - https://www.pvsm.ru -
Предположим есть группа в Вконтакте о кино, в которой публикуются анонсы новых фильмов и ещё какая-нибудь информация. Необходимо заранее подготавливать посты и публиковать по расписанию. Для этого я собираюсь использовать доску Trello, где хранятся посты и Вконтакте API чтобы публиковать эти посты в группе.
Создадим доску в Trello с названием "Кино", а в ней два листа "Новинки недели" и "Скоро в прокате". Добавим туда 4 карточки, 2 с публикацией на сегодня, 1 на завтра и 1 без даты.
Для работы с Trello API и Вконтакте API нам понадобятся следующие библиотеки.
$ pip3 install py-trello
$ pip3 install py-vkontakte
KEY и TOKEN получаем тут https://trello.com/app-key [1]
import trello
client = trello.TrelloClient(api_key=KEY, token=TOKEN)
board = client.get_board(ID) # например https://trello.com/b/nC8QJJoZ/, где ID — nC8QJJoZ
С помощью "Due Date" в карточке Trello мы задаём, время когда нужно опубликовать в Вконтакте.
def is_card_can_published(trello_card):
if not trello_card.due_date:
return False
now_unixtime = datetime.datetime.utcnow().replace(tzinfo=None).timestamp()
card_due_unixtime = trello_card.due_date.replace(tzinfo=None).timestamp()
delta = card_due_unixtime - now_unixtime
return True if delta <= 0 else False
card_items = (card for card in board.open_cards() if is_card_can_published(card))
Расписание публикаций можно посмотреть с помощью внутреннего календаря Trello.
К карточке можно прикрепить любой файл, поэтому предварительно проверяем расширение у файла. Функция get_attachment_in_card
возвращает кортеж "имя файла" и "байтовую строку изображения", который используются, для загрузки в ВК.
import os
import requests
def is_image_file(attachment_url):
_, file_extension = os.path.splitext(attachment_url)
if file_extension not in ('.jpg', '.gif', '.png'):
return False
return True
def download_attachment(attachment_url):
response = requests.get(attachment_url, stream=True)
return response.content
def get_attachment_in_card(card):
for attachment in card.get_attachments():
if not is_image_file(attachment.url):
continue
binary_content = download_attachment(attachment.url)
_, filename = os.path.split(attachment.url)
yield (filename, binary_content)
https://vk.com/dev/authcode_flow_user [3]
>>> import vk
>>> vk.create_url_get_code("ID_приложение", 'https://oauth.vk.com/blank.html', scope='wall, photos') # ссылка для получения CODE
>>> vk.create_access_token("ID_приложение", "Защищённый_ключ", "https://oauth.vk.com/blank.html", "CODE") # возвращает ACCESS_TOKEN
Получаем группу ВК через py-vkontakte
import vk
vk.set_access_token(ACCESS_TOKEN)
group = vk.get_group(ID) # vk.com/apiclub, где ID — apiclub или vk.com/club1, где ID — 1
Используем нашу функцию "get_attachment_in_card"
для получения изображения из карточки Trello. Загружаем изображения в ВК и создаем публикацию в группе. После публикации поста в Вконтакте, "due date" помечаем как выполненное.
from vk.photos import Photo
for card in card_items:
attachment_items =
{filename: binary_content for filename, binary_content in get_attachment_in_card(card)}
photo_items = Photo.upload_wall_photos_for_group(group.id, attachment_items.items())
group.wall_post(message=card.name + 'n' + card.description, attachments=photo_items)
card.set_due_complete()
→ GitHub [4]
Автор: sgaynetdinov
Источник [5]
Сайт-источник PVSM.RU: https://www.pvsm.ru
Путь до страницы источника: https://www.pvsm.ru/python/253521
Ссылки в тексте:
[1] https://trello.com/app-key: https://trello.com/app-key
[2] https://vk.com/editapp?act=create: https://vk.com/editapp?act=create
[3] https://vk.com/dev/authcode_flow_user: https://vk.com/dev/authcode_flow_user
[4] GitHub: https://github.com/sgaynetdinov/postin-in-vk-from-trello
[5] Источник: https://habrahabr.ru/post/327216/?utm_source=habrahabr&utm_medium=rss&utm_campaign=sandbox
Нажмите здесь для печати.