Форум программистов, компьютерный форум, киберфорум
Python: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 26.04.2023
Сообщений: 6

Проверка анкет в БД и пропуск уже существующих для добавления новых

21.06.2023, 10:15. Показов 790. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужна помощь в проверке анкеты в БД c соответствии с event.user_id. Если анкета уже была, то надо сделать следующий self.worksheets.pop() с помощью цикла While на месте комментария. Или какой-нибудь другой способ.
Это дипломная работа по боту в ВК. Если надо остальные модули - могу написать или скинуть ссылку на github.


Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
import vk_api
from vk_api.longpoll import VkLongPoll, VkEventType
from vk_api.utils import get_random_id
 
from config import comunity_token, acces_token
from core import VkTools
 
from data_store import engine, add_user, check_user 
 
 
class BotInterface():
    def __init__(self, comunity_token, acces_token):
        self.vk = vk_api.VkApi(token=comunity_token) 
        self.longpoll = VkLongPoll(self.vk)
        self.vk_tools = VkTools(acces_token)
        self.params = {}
        self.worksheets = []
        self.offset = 0
        
        
    def message_send(self, user_id, message, attachment=None):
        self.vk.method('messages.send',
                  {'user_id': user_id,
                   'message': message,
                   'attachment': attachment,
                   'random_id': get_random_id()})
 
        
    def event_handler(self):
        for event in self.longpoll.listen():
            if event.type == VkEventType.MESSAGE_NEW and event.to_me:
                if event.text.lower() == 'привет':
                    '''логика для получения данных о пользователе'''
                    self.params = self.vk_tools.get_profile_info(event.user_id)
                    self.message_send(event.user_id, f'Привет друг, {self.params["name"]}')
                elif event.text.lower() == 'поиск':
                    '''логика для поиска анкет'''
                    self.message_send(event.user_id, 'Начинаем поиск')
                    if self.worksheets:
                        worksheet = self.worksheets.pop() 
                        photos = self.vk_tools.get_photos(worksheet['id'])
                        photo_string = ''
                        for photo in photos:
                            photo_string += f'photo{photo["owner_id"]}_{photo["id"]},'
                    else:
                        self.worksheets = self.vk_tools.search_worksheets(
                            self.params, self.offset)
                        
                        worksheet = self.worksheets.pop()
                        
                        res = check_user(engine, event.user_id, worksheet['id'])
                        
                     
                        '''
                        проверка анкеты в БД c соответсвии с event.user_id
                        если анкета уже была то сделать следующий self.worksheets.pop()
                        с помощью цикла While
                        '''
                        
                        
                        photos = self.vk_tools.get_photos(worksheet['id'])
                        photo_string = ''
                        for photo in photos:
                            photo_string += f'photo{photo["owner_id"]}_{photo["id"]},'
                        self.offset += 50
                    self.message_send(
                        event.user_id,
                        f'имя: {worksheet["name"]} ссылка: vk.com/vk{worksheet["id"]}',
                        attachment = photo_string
                        )
                    
                    res = check_user(engine, event.user_id, worksheet['id'])
                    if res == False:
                        add_user(engine, event.user_id, worksheet['id'])
    
 
                elif event.text.lower() == 'пока':
                    self.message_send(event.user_id, 'До новых встреч')
                else:
                    self.message_send(event.user_id, 'Неизвестная команда')
        
        
if __name__ == '__main__':
    bot_interface = BotInterface(comunity_token, acces_token)
    bot_interface.event_handler()
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.06.2023, 10:15
Ответы с готовыми решениями:

Триггер на ограничение добавления уже существующих записей
ребят мне необходимо сделать триггер который при добавлений уже существующей записи выдовал ошбку!!! Я уже попробовал что-то сделать но у...

Запрет добавления в TreeView уже существующих там строк
Строка из поля edit помещается в treeview по нажатии на кнопку. как сделать так, чтобы, если такая строка уже существует, ее снова не...

Явное преобразования для уже существующих классов - возможно ли
Привет всем. Знаю что можно написать для своих класов явное и даже не явное преобразования. Но меня интересует можно ли для уже...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.06.2023, 10:15
Помогаю со студенческими работами здесь

Переменная в строке ввода (SET /P) для редактирования уже существующих данных
Стоит задача такого плана. Нужно при запросе данных не вводить постоянно имена и другие данные, а редактировать уже существующие прямо в...

Создать выборку из уже имеющихся анкет
Всем добрый вечер! Проблема достаточно простая,но решения ей найти не могу. Суть задачи: Из имеющихся уже анкет ( они были созданы в...

Сделать администраторскую форму для добавления новых форм
Проблема заключается в том что бы сделать форму для добавления новых форм в готовую программу и необходимо сделать разделение на двух...

Создание новых частей в скрипте для добавления пользователей!
Здрасте всем, подскажите можно ли создавать новых пользователей при регистрации в этом скрипте ........ if($login=aaaa and pass=bbbb...

Как создать страницу для добавления новых записей в базу данных?
Есть приложение, список компаний с разными параметрами( e-mail,телефон и т.д.). Можно ли создать html страничку, через которую в бд будут...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru