· 6 years ago · Apr 02, 2020, 10:44 AM
1#! /usr/bin/env python
2# -*- coding: utf-8 -*-
3import vk_api
4from vk_api.bot_longpoll import VkBotLongPoll
5from vk_api.utils import get_random_id
6from datetime import datetime, timezone
7import datetime
8import time
9import random
10import pyowm
11import requests, json # Модуль для обработки URL
12from bs4 import BeautifulSoup # Модуль для работы с HTML
13
14vk = vk_api.VkApi(token='3709764b230f73dbf6a6fca9c41e726af8c0e28eff5ea171f2e25d6b5d3761711e9cf46b77cbf3d7c47ba') #токен паблика
15
16class 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
25bot_id = '193179464' # сюда id паблика
26longpoll = MyVkLongPoll(vk, bot_id)
27
28def send_message(msg):
29 vk.method('messages.send',{'random_id':get_random_id(),'peer_id':event.obj.peer_id,'message':msg})
30
31def 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
40def 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
54def 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
68citymoscow = ['moscow','время мск' ,'мск', 'время москва'] #Время Москва UTC + 3
69sityekb = ['ект', 'екб', 'время екатеринбург', 'ekaterinburg', 'время екб'] #Время екб UTC +5
70
71course = ['курсы','курс', 'курсы валют', 'валюта', 'валюты', 'курс доллара', 'доллар', 'usd', 'евро', 'euro', 'курс евро', 'курсы валют', 'Валюта', 'нефть', 'курс нефти', 'oil'] #курсы валют
72kripta = ['крипта','криптовалюта','биткоин','kripta','крипто валюта']
73
74
75tlou2 = ['tlou', 'tlou2', 'тлоу', 'тлоу2']
76gost = ['gost', 'гост', 'тсушима']
77marvel = ['марвел', 'marvel\'s avengers', 'marvels avengers','мстители']
78cyberpunk = ['киперпанк','cyberpunk','cyberpunk 2077']
79
80koronavirus = ['коронавирус', 'covid', 'корона', 'вирус', 'coronavirus', 'мониторинг коронавируса']
81
82
83
84
85
86for 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('сам метод',{параметры метода})