2020-04-04 16:07:39 +00:00
import vk_api
import datetime
import requests
2020-04-04 21:18:12 +00:00
import logging
2020-04-05 14:41:33 +00:00
import pyowm
2020-04-05 22:46:06 +00:00
import random
2020-04-07 16:00:49 +00:00
import json
2020-04-06 10:26:50 +00:00
import wikipediaapi as wiki
2020-04-05 22:46:06 +00:00
from config import vk , owm , vk_mda
2020-04-03 19:56:57 +00:00
from vk_api . longpoll import VkLongPoll , VkEventType
2020-04-04 16:07:39 +00:00
2020-04-04 21:18:12 +00:00
bot_logger = logging . getLogger ( " dan63047bot " )
2020-04-04 16:07:39 +00:00
2020-04-03 21:18:34 +00:00
class VkBot :
2020-04-03 19:56:57 +00:00
2020-04-05 16:24:24 +00:00
def __init__ ( self , peer_id , user_id ) :
2020-04-04 16:07:39 +00:00
2020-04-04 21:18:12 +00:00
bot_logger . info ( " Создан объект бота! " )
2020-04-05 16:24:24 +00:00
self . _USER_ID = user_id
self . _CHAT_ID = peer_id
2020-04-03 19:56:57 +00:00
2020-04-07 16:00:49 +00:00
self . _COMMANDS = [ " !image " , " !my_id " , " !h " , " !user_id " , " !group_id " , " !help " , " !weather " , " !wiki " , " !byn " ]
2020-04-04 16:07:39 +00:00
2020-04-05 14:41:33 +00:00
def get_weather ( self , place ) :
logger = logging . getLogger ( " dan63047bot.get_weather " )
try :
weather_request = owm . weather_at_place ( place )
except pyowm . exceptions . api_response_error . NotFoundError as i :
logger . warning ( " Ошибка OpenWeather API: " + str ( i ) )
return " Такого города нет, либо данных о погоде нет "
weather_answer = weather_request . get_weather ( )
logger . info ( " Результат поиска погоды через OpenWeather API: " + str ( weather_answer ) )
return " В городе " + place + " сейчас " + weather_answer . get_detailed_status ( ) + " , " + str ( round ( weather_answer . get_temperature ( ' celsius ' ) [ ' temp ' ] ) ) + " °C "
2020-04-04 16:07:39 +00:00
def get_info_user ( self , id ) :
2020-04-04 21:18:12 +00:00
logger = logging . getLogger ( " dan63047bot.get_info_user " )
2020-04-04 16:07:39 +00:00
try :
user_info = vk . method ( ' users.get ' , { ' user_ids ' : id , ' fields ' : ' verified,last_seen,sex ' } )
except vk_api . exceptions . ApiError as lol :
2020-04-05 14:41:33 +00:00
logger . warning ( " Ошибка метода users.get: " + str ( lol ) )
return " Пользователь не найден<br> " + str ( lol )
2020-04-03 21:18:34 +00:00
2020-04-04 21:18:12 +00:00
logger . info ( " Результат метода API users.get: " + str ( user_info ) )
2020-04-04 16:07:39 +00:00
if user_info [ 0 ] [ ' is_closed ' ] :
is_closed = " Да "
else :
is_closed = " Нет "
if user_info [ 0 ] [ ' sex ' ] == 1 :
sex = " Женский "
elif user_info [ 0 ] [ ' sex ' ] == 2 :
sex = " Мужской "
else :
sex = " Неизвестно "
if user_info [ 0 ] [ ' last_seen ' ] [ ' platform ' ] == 1 :
platform = " m.vk.com "
elif user_info [ 0 ] [ ' last_seen ' ] [ ' platform ' ] == 2 :
platform = " iPhone "
elif user_info [ 0 ] [ ' last_seen ' ] [ ' platform ' ] == 3 :
platform = " iPad "
elif user_info [ 0 ] [ ' last_seen ' ] [ ' platform ' ] == 4 :
platform = " Android "
elif user_info [ 0 ] [ ' last_seen ' ] [ ' platform ' ] == 5 :
platform = " Windows Phone "
elif user_info [ 0 ] [ ' last_seen ' ] [ ' platform ' ] == 6 :
platform = " Windows 10 "
elif user_info [ 0 ] [ ' last_seen ' ] [ ' platform ' ] == 7 :
platform = " vk.com "
else :
platform = " тип платформы неизвестен "
time = datetime . datetime . fromtimestamp ( user_info [ 0 ] [ ' last_seen ' ] [ ' time ' ] )
answer = user_info [ 0 ] [ ' first_name ' ] + " " + user_info [ 0 ] [ ' last_name ' ] + " <br>Е г о ид: " + str ( user_info [ 0 ] [ ' id ' ] ) + " <br>Профиль закрыт: " + is_closed + " <br>Пол: " + sex + " <br>Последний онлайн: " + time . strftime ( ' %d . % m. % Y в % H: % M: % S ' ) + " ( " + platform + " ) "
return answer
def get_info_group ( self , id ) :
2020-04-04 21:18:12 +00:00
logger = logging . getLogger ( " dan63047bot.get_info_group " )
2020-04-04 16:07:39 +00:00
try :
group_info = vk . method ( ' groups.getById ' , { ' group_id ' : id , ' fields ' : ' description,members_count ' } )
except vk_api . exceptions . ApiError as lol :
2020-04-05 14:41:33 +00:00
logger . warning ( " Ошибка метода groups.getById: " + str ( lol ) )
return " Группа не найдена<br> " + str ( lol )
2020-04-03 21:18:34 +00:00
2020-04-04 21:18:12 +00:00
logger . info ( " Результат метода API groups.getById: " + str ( group_info ) )
2020-04-04 16:07:39 +00:00
if group_info [ 0 ] [ ' description ' ] == " " :
description = " Отсутствует "
else :
description = group_info [ 0 ] [ ' description ' ]
answer = group_info [ 0 ] [ ' name ' ] + " <br>Описание: " + description + " <br>Ид группы: " + str ( group_info [ 0 ] [ ' id ' ] ) + " <br>Подписчиков: " + str ( group_info [ 0 ] [ ' members_count ' ] )
return answer
2020-04-03 19:56:57 +00:00
2020-04-05 22:46:06 +00:00
def random_image ( self ) :
logger = logging . getLogger ( " dan63047bot.random_image " )
random_images_query = vk_mda . method ( ' photos.get ' , { ' owner_id ' : - 190322075 , ' album_id ' : 269199619 , ' count ' : 1000 } )
2020-04-06 10:26:50 +00:00
logger . info ( " Результат метода photos.get: Получено " + str ( random_images_query [ ' count ' ] ) + " фото " )
random_number = random . randrange ( random_images_query [ ' count ' ] )
2020-04-05 22:46:06 +00:00
return " photo " + str ( random_images_query [ ' items ' ] [ random_number ] [ ' owner_id ' ] ) + " _ " + str ( random_images_query [ ' items ' ] [ random_number ] [ ' id ' ] )
2020-04-06 10:26:50 +00:00
def wiki_article ( self , search ) :
w = wiki . Wikipedia ( ' ru ' )
page = w . page ( search )
if page . exists ( ) :
answer = page . title + " <br> " + page . summary
else :
answer = " Такой статьи не существует "
return answer
2020-04-07 16:00:49 +00:00
def exchange_rates ( self ) :
rates_USD = json . loads ( requests . get ( " https://www.nbrb.by/api/exrates/rates/145?periodicity=0 " ) . text )
rates_EUR = json . loads ( requests . get ( " https://www.nbrb.by/api/exrates/rates/292?periodicity=0 " ) . text )
rates_RUB = json . loads ( requests . get ( " https://www.nbrb.by/api/exrates/rates/298?periodicity=0 " ) . text )
return " Текущий курс валют по данным НБ РБ:<br> " + rates_USD [ ' Cur_Name ' ] + " : " + str ( rates_USD [ ' Cur_Scale ' ] ) + " " + rates_USD [ ' Cur_Abbreviation ' ] + " = " + str ( rates_USD [ ' Cur_OfficialRate ' ] ) + " BYN<br> " + rates_EUR [ ' Cur_Name ' ] + " : " + str ( rates_EUR [ ' Cur_Scale ' ] ) + " " + rates_EUR [ ' Cur_Abbreviation ' ] + " = " + str ( rates_EUR [ ' Cur_OfficialRate ' ] ) + " BYN<br> " + " Российский рубль " + " : " + str ( rates_RUB [ ' Cur_Scale ' ] ) + " " + rates_RUB [ ' Cur_Abbreviation ' ] + " = " + str ( rates_RUB [ ' Cur_OfficialRate ' ] ) + " BYN "
2020-04-03 21:18:34 +00:00
def new_message ( self , message ) :
2020-04-04 16:07:39 +00:00
respond = { ' attachment ' : None , ' text ' : None }
2020-04-06 10:26:50 +00:00
message = message . split ( ' ' , 1 )
2020-04-04 16:07:39 +00:00
if message [ 0 ] == self . _COMMANDS [ 0 ] :
2020-04-05 22:46:06 +00:00
respond [ ' attachment ' ] = self . random_image ( )
2020-04-03 19:56:57 +00:00
2020-04-04 16:07:39 +00:00
elif message [ 0 ] == self . _COMMANDS [ 1 ] :
respond [ ' text ' ] = " Ваш ид: " + str ( self . _USER_ID )
2020-04-03 19:56:57 +00:00
2020-04-04 16:07:39 +00:00
elif message [ 0 ] == self . _COMMANDS [ 2 ] or message [ 0 ] == self . _COMMANDS [ 5 ] :
2020-04-07 16:08:17 +00:00
respond [ ' text ' ] = " Я бот, призванный доставлять неудобства. <br>Команды:<br>!my_id - сообщит ваш id в В К <br>!user_id *id* - сообщит информацию о этом пользователе<br>!group_id *id* - сообщит информацию о этой группе<br>!image - отправляет рандомную картинку из альбома<br>!weather *город* - отправляет текущую погоду в городе (данные из OpenWeather API)<br>!wiki *запрос* - отправляет информацию о б этом из Wikipedia<br>!byn - отправляет текущий курс валют, полученный из API НБ РБ<br>!h, !help - справка<br>Дата последнего обновления: 07.04.2020<br>Проект бота на GitHub: https://github.com/dan63047/dan63047pythonbot "
2020-04-03 19:56:57 +00:00
2020-04-04 16:07:39 +00:00
elif message [ 0 ] == self . _COMMANDS [ 3 ] :
2020-04-05 14:41:33 +00:00
try :
respond [ ' text ' ] = self . get_info_user ( message [ 1 ] )
except IndexError :
respond [ ' text ' ] = " Отсуствует аргумент "
2020-04-03 19:56:57 +00:00
2020-04-04 16:07:39 +00:00
elif message [ 0 ] == self . _COMMANDS [ 4 ] :
2020-04-05 14:41:33 +00:00
try :
2020-04-06 10:26:50 +00:00
respond [ ' text ' ] = self . get_info_group ( message [ 1 ] )
2020-04-05 14:41:33 +00:00
except IndexError :
respond [ ' text ' ] = " Отсуствует аргумент "
elif message [ 0 ] == self . _COMMANDS [ 6 ] :
try :
2020-04-06 10:26:50 +00:00
respond [ ' text ' ] = self . get_weather ( message [ 1 ] )
except IndexError :
respond [ ' text ' ] = " Отсуствует аргумент "
elif message [ 0 ] == self . _COMMANDS [ 7 ] :
try :
respond [ ' text ' ] = self . wiki_article ( message [ 1 ] )
2020-04-05 14:41:33 +00:00
except IndexError :
respond [ ' text ' ] = " Отсуствует аргумент "
2020-04-07 16:00:49 +00:00
elif message [ 0 ] == self . _COMMANDS [ 8 ] :
respond [ ' text ' ] = self . exchange_rates ( )
2020-04-04 16:07:39 +00:00
return respond