Advertisement
Guest User

Untitled

a guest
Apr 2nd, 2020
956
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 13.53 KB | None | 0 0
  1. #! /usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. import vk_api
  4. from vk_api.bot_longpoll import VkBotLongPoll
  5. from vk_api.utils import get_random_id
  6. from datetime import datetime, timezone
  7. import datetime
  8. import time
  9. import random
  10. import pyowm
  11. import requests, json # Модуль для обработки URL
  12. from bs4 import BeautifulSoup # Модуль для работы с HTML
  13.  
  14. vk = vk_api.VkApi(token='3709764b230f73dbf6a6fca9c41e726af8c0e28eff5ea171f2e25d6b5d3761711e9cf46b77cbf3d7c47ba') #токен паблика
  15.  
  16. class MyVkLongPoll(VkBotLongPoll): # создаю класс чтобы он не терял соединение с сервером вк когда тот перезагружается (перезагружается раз в день где-то глубоко ночью)
  17. def listen(self):
  18. while True:
  19. try:
  20. for event in self.check():
  21. yield event
  22. except Exception as e:
  23. print(e) #будет писать в консоль что таймаут произошел, при желании просто впишите сюда pass
  24.  
  25. bot_id = '193179464' # сюда id паблика
  26. longpoll = MyVkLongPoll(vk, bot_id)
  27.  
  28. def send_message(msg):
  29. vk.method('messages.send',{'random_id':get_random_id(),'peer_id':event.obj.peer_id,'message':msg})
  30.  
  31. def game(name, date1,date2,date3):
  32. # Значение: datetime.datetime(2017, 4, 5, 0, 18, 51, 980187)
  33. now = datetime.datetime.now()
  34. then = datetime.datetime(date1,date2,date3)
  35. time = then - now
  36. days = time.days
  37. send_message(str(name) + str(days) + ' days' )
  38.  
  39.  
  40. def get_id(text): #функция для удобного получения id из всего сообщения
  41. split_msg = text.split(' ')
  42. for i in split_msg:
  43. if 'id' in i:
  44. if '-' in i:
  45. id = i.split('|')[0].replace('@id-','')
  46. return -(int(id))
  47. id = i.split('|')[0].replace('[id','')
  48. return int(id)
  49. elif 'club' in i:
  50. id = i.split('|')[0].replace('[club','')
  51. return -(int(id))
  52. id_from_message = get_id(event.obj.text)
  53.  
  54. def cryptofunc(URL, clas, btc):
  55. BTC = URL
  56.  
  57. ist = requests.get(BTC)
  58.  
  59. textbtc = ist.text
  60.  
  61. soupbtc = BeautifulSoup(textbtc)
  62.  
  63. tablebtc3 = soupbtc.findAll("span", {"class": clas})
  64.  
  65. send_message(name + str(tablebtc3[0].text))
  66.  
  67.  
  68. citymoscow = ['moscow','время мск' ,'мск', 'время москва'] #Время Москва UTC + 3
  69. sityekb = ['ект', 'екб', 'время екатеринбург', 'ekaterinburg', 'время екб'] #Время екб UTC +5
  70.  
  71. course = ['курсы','курс', 'курсы валют', 'валюта', 'валюты', 'курс доллара', 'доллар', 'usd', 'евро', 'euro', 'курс евро', 'курсы валют', 'Валюта', 'нефть', 'курс нефти', 'oil'] #курсы валют
  72. kripta = ['крипта','криптовалюта','биткоин','kripta','крипто валюта']
  73.  
  74.  
  75. tlou2 = ['tlou', 'tlou2', 'тлоу', 'тлоу2']
  76. gost = ['gost', 'гост', 'тсушима']
  77. marvel = ['марвел', 'marvel\'s avengers', 'marvels avengers','мстители']
  78. cyberpunk = ['киперпанк','cyberpunk','cyberpunk 2077']
  79.  
  80. koronavirus = ['коронавирус', 'covid', 'корона', 'вирус', 'coronavirus', 'мониторинг коронавируса']
  81.  
  82.  
  83.  
  84.  
  85.  
  86. for event in longpoll.listen(): #начинаем слушать лонгпулл
  87. if event.obj:
  88. if event.obj.text.lower() in ('комманды', '/комманды', 'commands', '/commands','команды'):
  89. send_message('Вот что я умею: \n1. /rand "число1-число2" \n2. Время "город" \n3. Погода "Город" \n4. Курсы валют \n5. Мониторинг коронавируса \
  90. \n6. Дата выхода Gost/tlou2/Marvel Avenger\'s/Cyberpunk 2077 \n7.Орёл/Решка')
  91. print(event.obj.text)
  92. elif event.obj.text.lower() == 'привет':
  93. send_message('привет')
  94. print(event.obj.text)
  95. elif event.obj.text.lower() == 'пока':
  96. send_message('пока')
  97. print(event.obj.text)
  98. id_from_message = event.obj.from_id
  99. ids = get_id(event.obj.text)
  100. print(id_from_message)
  101. print(ids)
  102.  
  103. #elif event.obj.text.lower() == 'kick':
  104. #chat_id = int(str(event.obj.peer_id)[-1:])
  105. #vk.method('messages.removeChatUser',{'chat_id':chat_id,'member_id':504708567})
  106.  
  107. elif event.obj.text.lower() in kripta:
  108. BTC = 'https://www.coingecko.com/ru'
  109.  
  110. ist = requests.get(BTC)
  111.  
  112. textbtc = ist.text
  113.  
  114. soupbtc = BeautifulSoup(textbtc)
  115.  
  116. tablebtc = soupbtc.findAll("span", {"class": 'no-wrap'})
  117. tablebtc1 = soupbtc.findAll("span", {"data-coin-id": '1'})
  118.  
  119. tableeth1 = soupbtc.findAll("span", {"data-coin-id": '279'})
  120.  
  121. send_message('BTC = ' + str(tablebtc[0].text) + ' $ ' + '▲' + str(tablebtc1[2].text) + ' за день'\
  122. '\n ETH = ' + str(tableeth1[0].text) + ' $ ' + '▲' + str(tableeth1[2].text) + ' за день' )
  123.  
  124. elif event.obj.text.lower() in course:
  125.  
  126. oil = 'https://yandex.ru/news/quotes/1006/'
  127. dollar_rub = 'https://yandex.ru/news/quotes/1.html'
  128. euro_rub = 'https://yandex.ru/news/quotes/23.html'
  129. CNY = 'https://yandex.ru/news/quotes/10018.html'
  130. # Парсим всю страницу
  131. source1 = requests.get(dollar_rub)
  132. source2 = requests.get(euro_rub)
  133. source3 = requests.get(oil)
  134. source4 = requests.get(CNY)
  135.  
  136. main_text1 = source1.text
  137. main_text2 = source2.text
  138. main_text3 = source3.text
  139. main_text4 = source4.text
  140. # Разбираем через BeautifulSoup
  141. soup1 = BeautifulSoup(main_text1)
  142. soup2 = BeautifulSoup(main_text2)
  143. soup3 = BeautifulSoup(main_text3)
  144. soup4 = BeautifulSoup(main_text4)
  145.  
  146. # Получаем нужное для нас значение и возвращаем его
  147. table1 = soup1.findAll("td", {"class": "quote__value"})
  148. table2 = soup2.findAll("td", {"class": "quote__value"})
  149. table3 = soup3.findAll("td", {"class": "quote__value"})
  150. table4 = soup4.findAll( "td", { "class": "quote__value" } )
  151. #tr = table.find( "span", { "class": "quote__sgn" } )
  152.  
  153.  
  154. send_message('Доллар = ' + str(table1[0].text[:5]) + ' рублей' + '\nЕвро = ' + str(table2[0].text[:5]) + ' рублей' +\
  155. '\nЮань = ' + str(table4[0].text[:5]) + ' Рублей' + '\n ' + '\nНефть = ' + str(table3[0].text) + ' USD' )
  156.  
  157.  
  158. elif event.obj.text.lower() in koronavirus:
  159. oil = 'https://dev.by/news/poyavilsya-onlain-servis-dlya-monitoringa-rasprostraneniya-koronavirusa'
  160.  
  161. source = requests.get(oil)
  162. main_text = source.text
  163. soup = BeautifulSoup(main_text)
  164.  
  165. USA = soup.findAll( "", { "class": "data row1 col1"} )
  166. ITALIA = soup.findAll( "", { "class": "data row2 col1"} )
  167. SPANISH = soup.findAll( "", { "class": "data row3 col1"} )
  168. CHINA = soup.findAll( "", { "class": "data row4 col1"} )
  169. GERMANY = soup.findAll( "", { "class": "data row5 col1"} )
  170. RUSSIA = soup.findAll( "", { "class": "data row32 col1"} )
  171.  
  172. send_message('Заражённых в сша: ' + str(USA[0].text) + '\nЗаражённых в Италии ' + str(ITALIA[0].text))
  173.  
  174.  
  175.  
  176. elif 'погода' in event.obj.text.lower():
  177.  
  178. # Enter your API key here
  179. #api_key = "c012abf83e8afdf40810863f64ae8618"
  180.  
  181. # base_url variable to store url
  182. #base_url = "http://api.openweathermap.org/data/2.5/weather?"
  183. # Give city name
  184. owm = pyowm.OWM('c012abf83e8afdf40810863f64ae8618', language = 'ru')
  185.  
  186. try:
  187. city_name = event.obj.text.split(' ')[1:][0] #Получаем всё, что идёт после "погода"
  188.  
  189. #pyowm
  190. observation = owm.weather_at_place(city_name)
  191. w = observation.get_weather()
  192. temp = w.get_temperature('celsius')['temp']
  193. status = w.get_detailed_status()
  194.  
  195. # print following values
  196. send_message(" Температура (в цельсиях): " +
  197. str(temp) + '°' +
  198. #"\n atmospheric pressure (in hPa unit) = " +
  199. #str(current_pressure) +
  200. #"\n humidity (in percentage) = " +
  201. #str(current_humidiy) +
  202. "\n Состояние: " +
  203. str(status))
  204. except:
  205. send_message('Город не найден')
  206.  
  207.  
  208. elif '/rand' in event.obj.text.lower():
  209. spis = event.obj.text.split(' ')[1:] #Получаем всё, что идёт после "рандом"
  210. pered = event.obj.text.split(' ')[:1] #Получаем всё, что идёт перед "рандом"
  211. pred = ' '.join(pered)
  212.  
  213. if len(spis)>1:
  214. send_message('Неправильно набрана команда!')
  215. elif pred != '/rand':
  216. send_message('ты нахуй пишешь чото перед /rand')
  217. continue
  218. else:
  219. try:
  220. first_number = int(spis[0].split('-')[0]) #Получаем первое число деля строку с числами на две
  221. second_number = int(spis[0].split('-')[1]) #Получаем второе число
  222. random_num = random.randint(first_number, second_number)
  223. send_message(str('Рандомное число: ' + str(random_num)))
  224. except:
  225. send_message('неправильные числа представлены!')
  226.  
  227.  
  228.  
  229. elif 'орёл/решка' in event.obj.text.lower():
  230. Headstails = random.randint(1,2)
  231.  
  232. if Headstails == 1:
  233. d = 'Орёл'
  234. elif Headstails == 2:
  235. d = 'Решка'
  236. send_message(str(d))
  237.  
  238.  
  239.  
  240. elif event.obj.text.lower() in tlou2:
  241. game('Until the release of "The Last of Us Part 2" left to wait ' , 2020,5,29)
  242.  
  243.  
  244. elif event.obj.text.lower() in gost:
  245. game('Until the release of "Ghost of Tsushima" left to wait ', 2020, 6, 26)
  246.  
  247. elif event.obj.text.lower() in cyberpunk:
  248. game('Until the release of "Cyberpunk 2077" left to wait ', 2020, 9, 17)
  249.  
  250. elif event.obj.text.lower() in marvel:
  251. game('Until the release of "Marvel\'s Avengers" left to wait ', 2020, 9, 4)
  252.  
  253.  
  254.  
  255.  
  256.  
  257.  
  258.  
  259.  
  260.  
  261.  
  262. elif 'время' in event.obj.text.lower():
  263. utcp3 = ['москва','киров','адлер','азов','анапа','арзамас','балашиха','балахна','белгород','бор','владимир','воронеж',\
  264. 'вязьма','казань','липецк','пенза','тверь','тамбов','сочи','смоленск','псков','подольск','питер','санкт-петербург','киев','минск','нижний-новгород']
  265. time = datetime.datetime.now(timezone.utc)
  266. utc3 = time.hour + 3
  267. if utc3 > 24:
  268. a = utc3 - 24
  269. else:
  270. a = time.hour + 3
  271. st = (str(a) + ':' + str(time.minute) + ':' + str(time.second) )
  272.  
  273. spis = event.obj.text.split(' ')[1:] #Получаем всё, что идёт после "время"
  274. city_name = ' '.join(spis)
  275. city = city_name.lower()
  276.  
  277. pered = event.obj.text.split(' ')[:1] #Получаем всё, что идёт перед "время"
  278. pered = ' '.join(pered)
  279. pered = pered.lower()
  280.  
  281. if city in utcp3:
  282. send_message('В городе ' + str(city.title()) + ' сейчас: ' + str(st))
  283. continue
  284. #elif len(spis)
  285. elif len(spis) < 3:
  286. if pered != 'время':
  287. send_message('ты нахуй пишешь чото перед время')
  288. continue
  289. elif city not in utcp3:
  290. send_message('Город не найден!')
  291. continue
  292.  
  293. print(pered)
  294.  
  295.  
  296. #elif event.obj.text.lower() in sityekb:
  297.  
  298.  
  299.  
  300.  
  301. elif event.obj.text.lower() == 'кик':
  302. try:
  303. chat_id = int(str(event.obj.peer_id)[-1:])
  304. user_id = event.obj['reply_message']['from_id']
  305. vk.method("messages.removeChatUser", {"chat_id": chat_id ,"user_id": user_id })
  306. except Exception as e:
  307. print(e)
  308.  
  309.  
  310. # vk.method('сам метод',{параметры метода})
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement