Задать вопрос
  • Как исправить ошибку SQLite3, Discord Bot?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Смотри, допустим, emoji у тебя равно :duck:, тогда будет выполнен следующий запрос:

    INSERT INTO emo VALUES (:duck:)

    А надо было:

    INSERT INTO emo VALUES (':duck:')

    Теперь понятно?

    Ладно, допусим, ты вставишь в запрос кавычки, дальше кто-нибудь добавит в код эмодзи кавычки и сможет заставить скрипт выполнить такой запрос:

    INSERT INTO emo VALUES ('');DROP TABLE emo;--')

    После чего таблица emo будет удалена. Нельзя просто так вставлять в запрос то, что передаёт пользователь. Надо использовать плейсхолдеры:

    cursor.execute("INSERT INTO emo VALUES (?)", (emoji,))


    В этом случае база сама позаботится о том, чтобы правильно использовать значения в запросах с учётом синтаксиса.
    Ответ написан
    Комментировать
  • При входе на сервер функция отвечающая за ввод данных в db не работает. тоже самое происходит с функцией, которая вызывается коммандой. что делать?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    По умолчанию Discord не присылает события on_member_join, для этого надо явно включить member intents.

    intents = discord.Intents.default()
    intents.members = True
    client = commands.Bot(command_prefix='!', intents=intents)
    Ответ написан
    Комментировать
  • Как стилизовать вывод данных в консоли?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    В общем случае см. man console_codes.
    Ответ написан
    Комментировать
  • Какую информацию про неизвестный угол надо добавлять, чтобы его можно было точно определить?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Потому что площадь равна половине произведения длин этих сторон на синус угла между ними, а угол может быть острым или тупым с одним и тем же значением синуса. Например, если стороны равны 1 и площать 1/4, то уголь может быть 30 градусов или 150 градусов.
    Ответ написан
    Комментировать
  • Сменить ID профиля ВКонтакте в базе данных ВК?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Да, id пользователя неизменен. Можно только удалить пользователя и создать нового, тогда его id будет другим.
    Ответ написан
    Комментировать
  • Multiprocessing читает каждую строчку из txt файла на каждом процессоре?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Один из самых простых способов это сделать - назначить каждому процессу из N штук свой номер и пусть первый читает строки 1, N+1, 2N+1, ..., второй 2, N+2, 2N+2, ... и так далее. Строки других процессов просто пропускать.

    # number - номер процесса от 0 до total-1
    # total - всего процессов
    def process(number, total):
       for i, l in enumerate(f):
          if i % total == number:
              ...
    Ответ написан
    Комментировать
  • Как получить сообщение канала telegram в переменную (парсер)?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Если канал свой (или есть связи с владельцами), то можно подписать на него своего бота и ловить события. Использовать обычные библиотеки для Bot API (telebot, aiogram итд).

    Если канал чужой, то бота подписать не получится, необходимо использовать клиентский API, изображающий обычного пользователя (библиотеки telethon, pyrogram).
    Ответ написан
  • Как из string сделать list Python?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Даже если обернуть last_name в кавычки, это не будет валидный json, потому что в json кавычки должны быть двойные. Самый простой способ это решить - использовать ast.literal_eval - так как указанный код является валидным кодом на python:

    import ast
    s = "[{'name': 'Рулон', 'last_name': 'Обоев'}, {'name': 'Лежана', 'last_name': 'Раздвиногова'}]"
    print (repr(ast.literal_eval(s)))


    Почему не просто eval? Потому что это более безопасно. Если в качестве "данных" нам прилетит

    os.system("rm -rf /some/file")

    то eval выполнит этот код и удалит файл как ни в чём не бывало, а ast.literal_eval кинет исключение.
    Ответ написан
    Комментировать
  • Как починить код запуска программы?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Судя по всему, речь идёт о боте для Discord? Этот код не будет работать. И довольно очевидно, что с твоим текущим уровнем знаний Python шансов заставить это работать нет.
    Ответ написан
    Комментировать
  • BadRequest: Unsupported parse_mode?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Скорее всего, в недрах create_bot (который не приведён в вопросе) используется parse_mode с неверным значением.
    Ответ написан
    Комментировать
  • Можно ли добавить два одинаковых бота в один аккаунт в телеграмме?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Нет, нельзя.
    Ответ написан
    Комментировать
  • Как обратиться к бд если она занята другой программой?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Как вариант, создаётся lock file рядом с базой, и все процессы, которые с ней работают, ставят эксклюзивную блокировку перед любой операцией с базой, а после её выполнения её снимают. Но всё же рекомендую перейти на самостоятельную СУБД.
    Ответ написан
    Комментировать
  • Маршрутизация 2 eth с перенаправлением?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Сервер не отправляет "с основного eth1". Интерфейс для отправки выбирается в процессе маршрутизации, а не до неё.

    ip route add 79.79.79.9 via шлюз_в_сети_где_адрес_78.78.78.3


    Это изменит в рантайме, после перезагрузки / переподключения к сети маршрут слетит и его надо будет прописывать заново. Чтобы поднимался автоматически, надо смотреть, какой механизм управления сетью используется (ifupdown/netplan/network-manager/network-scripts/dhcp client/итд/итп), и решать в зависимости от.
    Ответ написан
    Комментировать
  • Как получить фото с помощью телеграм бот api?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Они там поленились документацию написать. Но нетрудно понять, что следует использовать метод downloadFile https://github.com/TelegramBot/Api/blob/master/src...
    Ответ написан
    Комментировать
  • В чём ошибка определения переменной экземпляра?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Рекомендую напечатать id объектов, сразу станет видно проблему:

    for i in range(11):
      print (f"`{i} {id(g[i])}")
      for j in range(7):
        print (f"  `{j} {id(g[i][j])}")
        #deb.write(str(i)+"-"+str(j)+" "+str(g[i][j].x)+" "+str(g[i][j].y)+"\r\n")


    кусочек вывода
    `0 140084785493632
      `0 140084785519824
      `1 140084785520544
      `2 140084785519872
      `3 140084785520016
      `4 140084785520448
      `5 140084785520592
      `6 140084785520112
    `1 140084785493632
      `0 140084785519824
      `1 140084785520544
      `2 140084785519872
      `3 140084785520016
      `4 140084785520448
      `5 140084785520592
      `6 140084785520112


    Все элементы списка длины 11 по первому индексу ссылаются на один и тот же массив длины 7

    Ошибка тут в том, что выражение

    some_list * 11

    конструирует список из 11 ссылок на один и тот же массив. Который на последней итерации цикла получает x=10 во всех элементах.

    Решить можно, например, так:

    g = []
    
    for i in range(11):
      g.append([])
      for j in range(7):
        g[i].append(Point(i, j))


    В python все объекты передаются по ссылке, и это надо учитывать, а при необходимости копировать их явно.
    Ответ написан
    Комментировать
  • Как мне сделать такую статистику на discord.py?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Видно же, что это голосовые каналы.

    Нужно создать два голосовых канала с закрытым для всех доступом, в имени которых указать число пользователей. Также в боте отслеживать приходящих-уходящих и переименовывать эти каналы. Предвосхищая вопросы, напомню, что за готовыми решениями добро пожаловать на фриланс.
    Ответ написан
  • Отправка файла через телеграм бота с помощью libcurl с определенным параметром?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Если по ссылке, то надо передать ссылку в URL: ...&document=ссылка

    Если файл лежит локально, то передать файл в multipart/form-data, как-то примерно так: https://curl.se/libcurl/c/postit2.html
    Ответ написан
    Комментировать
  • Есть ли в Telegram возможность отправлять сообщение через вебхук, или что-то подобное?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    API Телеграма сам по себе решает эту задачу, например, отправка текстового сообщения выглядит так:

    https://api.telegram.org/botТОКЕН/sendMessage?chat_id=-12345&text=Сообщение


    Отправка фото через /sendPhoto, отправка видео с помощью /sendVideo, итд.
    Ответ написан
    Комментировать
  • Исключение вызывается даже при его обработке?

    shurshur
    @shurshur
    Сисадмин, просто сисадмин...
    Что при обработке исключения может случиться другое исключение это как раз нормально. Ненормально, что всё это маскируется отлавливанием корневного класса Exception.

    Плохая практика ловить любой Exception и даже не выводить его содержание с помощью хотя бы обычного print. Например, в недрах вызываемого кода ошибка из-за исчерпания места на диске, в обработчике вызываешь опять этот код и в недрах случается то же самое. Там вообще может случиться что угодно. Закончиться память в абсолютно любой строчке, например.

    Также плохая практика генерировать абстрактный Exception на конкретную ошибку. Это может быть пригодно для набросанного для разового запуска скрипта, но в целом плохо, тем более это не сложно решается:

    class NoTrainDataLoaded(Exception):
        pass
    
    ...
    raise NoTrainDataLoaded("Call your_model_object.load_train_data first!")
    
    ...
    try:
        ...
    except NoTrainDataLoaded:
        logger.info("Train data not loaded yet, load default data...")
        my_model.load_train_data("mimimi-cats-and-dogs")
        continue


    Если вдруг случится исключение, которое не упомянуто в except, то скрипт упадёт, и это хорошо. Пусть он не пытается делать какую попало реакцию на неясно какую ошибку.
    Ответ написан
    Комментировать