Задать вопрос
  • Как реализовать систему изменения данных в базе данных?

    Vindicar
    @Vindicar
    RTFM!
    Ну во-первых, если ты используешь aiogram, то про многопоточность лучше забыть. Асинхронность с многопоточностью сочетается довольно плохо. Это возможно, но нетривиально, и новичкам лучше не связываться.
    Во-вторых, дай угадаю - задержку в цикле фарминга реализуешь через time.sleep()? Если да, то конечно, цикл асинхронной программы останавливается на это время. Вот почему предусмотрена функция asyncio.sleep(), которая может приостановить выполнение отдельной корутины, не трогая остальных.
    В-третьих, если тебе нужно выполнить корутину и дождаться результата её выполнения - используй оператор await. Если же тебе нужно запланировать выполнение корутины и идти дальше, не дожидаясь её результата (выполнение "как только, так сразу") - лучше использовать asyncio.get_event_loop().create_task().

    Думаю, остальное сможешь додумать сам.
    Ответ написан
    5 комментариев
  • Как динамически вызвать функцию из подключенной dll?

    Vindicar
    @Vindicar
    RTFM!
    Ну так-то модуль ctypes в помощь, но ты сначала научись выражать свои мысли...
    вызвать переменную, которая вернется как integer = 0?
    Ответ написан
    Комментировать
  • Что делает "..." в Python?

    Vindicar
    @Vindicar
    RTFM!
    Вообще обычно это заглушка. Но это уникальное значение (как None), и его можно использовать для своих целей, при желании.
    Например, в numpy он используется так: если у нас есть массив с 3 измерениями, и мы хотим задать срез по третьему измерению, мы можем записать либо так array[:, :, 0] либо так array[..., 0].
    По-моему, еще в typing есть применения.
    Ответ написан
    Комментировать
  • Как сделать активность бота на discord.py?

    Vindicar
    @Vindicar
    RTFM!
    Плохо искал.
    Client.change_presence (наследуется классом Bot)
    BaseActivity - предок возможных активностей.
    Ответ написан
    Комментировать
  • Что делает команда cls < NUL?

    Vindicar
    @Vindicar
    RTFM!
    Ну вообще < - это перенаправление ввода программы, так же как > - перенаправление стандартного вывода программы. NUL - это устройство (псевдофайл), точнее пустое устройство. Вывод в него не даёт ничего, а ввод эквивалентен чтению пустого файла.
    Вот только зачем это cls...
    Ответ написан
    Комментировать
  • Как связать несвязанные друг с другом теги через bs4?

    Vindicar
    @Vindicar
    RTFM!
    Если вся эта красота лежит в одном родителе (ну или ты можешь засунуть всё это в один список в правильном порядке), то тривиально.
    sections = []
    current_section = None
    paragraphs = []
    for tag in tags: # перебираем теги, которые надо обработать
        if tag.name == 'h2':
            if current_section is not None:
                sections.append( (current_section, paragraphs) )
            current_section = tag
            paragraphs = []
        elif tag.name == 'p':
            paragraphs.append(tag)
    if current_section is not None:
        sections.append( (current_section, paragraphs) )

    В secitons будет лежать список кортежей вида (заголовок, список параграфов) в том порядке, в котором они идут в тексте. Твоя забота - обеспечить правильное значение tags.
    Ответ написан
    Комментировать
  • Как выводить сообщение без остановки?

    Vindicar
    @Vindicar
    RTFM!
    Ну во-первых ты творишь какой-то колхоз. discord.py тащит как зависимость асинхронную aiohttp, а ты сначала используешь синхронный requests, а потом заворачиваешь его в асинхрон через ThreadPool, потом обратно заворачиваешь в синхронный код в main(), а потом этот main() хочешь использовать вместе с асинхронным кодом discord.py. Жесть.
    Вот не проще осилить изначально асинхронную библиотеку, которую и так и так придётся использовать?

    Далее, что за бредятина с while? Что, по-твоему, должен делать вызов on_ready() в цикле? Что еще за точки с запятыми в питоне?
    Ты делаешь чисто синхронный бесконечный цикл, естественно этот цикл не даёт асинхронному коду исполняться.

    Ну и до кучи зачем-то используешь discord.Client вместо discord.Bot.

    Даже базового знания того, как работает асинхронность в питоне, достаточно, чтобы набросать код вида:
    import asyncio
    import aiohttp
    import discord
    from discord.ext import commands
    client = commands.Bot(intents = discord.Intents.default())
    
    async def fetch():
        return ... # тут вытаскиваем данные с сайта через aiohttp и возвращаем в удобном нам виде
    
    async def display(results):
        global client
        pass  # тут выводишь результаты в дискорд, используя объект client
    
    async def cycle():
        while True:
            res = await fetch()  # обработку ошибок допиши сам
            await display(res)
            await asyncio.sleep(300)  # задержка в секундах
    
    cycle_task = None
    @client.ready
    async def on_ready():
        global cycle_task
        if cycle_task is None:  # событие ready может отрабатывать несколько раз, нам нужен только один.
            cycle_task = asyncio.get_event_loop().create_task(cycle())
        pass  # тут делаешь что тебе еще нужно по запуску бота
    
    # когда надо будет остановить цикл, вызови cycle_task.cancel()
    bot.run(TOKEN)  # запускаешь бота
    Ответ написан
    Комментировать
  • Как работает wa?

    Vindicar
    @Vindicar
    RTFM!
    Подозреваю, что wa не в курсе, что ты поменял номер, а новый владелец номера не в курсе, что к его номеру привязана учётка в каком-то мессенджере.
    Тащем-то, ещё одна причина почему мессенджеры с привязкой по мобильному - зло.
    Ответ написан
    Комментировать
  • Как сделать цикл не задерживающий программу в Python?

    Vindicar
    @Vindicar
    RTFM!
    Ну для начала, что значит "не задерживал"? Если последующий код зависит от результата работы этого цикла, толку всё равно не будет.
    Так что первым делом определись для себя, какие куски кода ты хочешь выполнять параллельно и почему. Вынеси эти фрагменты в отдельные функции.
    Далее, реализовать более-менее параллельное выполнение можно через threading.Thread, но там есть целый ряд подводных камней. В первую очередь, доступ на запись (или на чтение и запись) к одной и той же переменной из двух потоков. Во вторую, как следствие - умение передать исходные данные в другой поток и дождаться результата работы из другого потока. В третью - объекты из некоторых библиотек нормально работают только в пределах одного потока, передавать их между потоками нельзя.
    Ответ написан
    Комментировать
  • Python — Невозможно создать экземпляр абстрактного класса ... с помощью абстрактных методов?

    Vindicar
    @Vindicar
    RTFM!
    Отступы косые, будь внимательнее.
    У тебя check() объявлена как локальная функция внутри __init__(), соответственно в самом классе такого метода нет. А так как метод объявлен абстрактным в BoundFilter и не переопределён в твоём классе, то и твой класс остаётся абстрактным. А потому попытка создать его экземпляр проваливается.
    Ответ написан
    Комментировать
  • Как реализовать сеть по генерации геометрического изображения из скетча?

    Vindicar
    @Vindicar
    RTFM!
    Нейронные сети тебе не помогут, если ты не знаешь, как извлечь исходную информацию из изображения. Да и потом, где ты найдешь несколько десятков/сотен тысяч изображений для обучения сети? Нейронки - это не магия, чтобы вжух и оно само. -_-

    Я бы попробовал найти все встречающиеся цвета пикселей и кластеризовать их, но дело осложняется тем, что заранее неизвестно количество используемых цветов. После этого можно будет выделить каждую черкотню отдельно, сравнив цвет пикселя с центром того или иного кластера, а потом разделив отдельные фрагменты через поиск связных компонентов.
    Далее можно взять за основу вот этот алгоритм.
    ну или немного иначе

    Для каждого фрагмента определи описывающий выпуклый многоугольник, чтобы избежать мути с неровной штриховкой внутри.
    Затем переведи этот многоугольник в полярные координаты. Для этого найди центр масс этого многоугольника. Потом из этой точки пускаешь наружу лучи, по кругу, с некоторым шагом (скажем 1 градус), и считаешь расстояние от центра масс до точки пересечения луча с многоугольником. Ты получишь своего рода профиль фигуры, зависимость расстояния от центра фигуры от направления, в котором мы смотрим.
    Этот профиль можно сравнить с профилями заранее известных фигур - треугольников, прямоугольников, эллипсов - чтобы понять, на что фрагмент походит больше всего.
    Чтобы сравнение было проще, стоит сделать так. Сдвинь многоугольник так, чтобы центр масс попал в (0;0). Найди вершину многугольника, которая наиболее удалена от центра. Поверни многоугольник так, чтобы она смотрела, скажем, под уголом 45 градусов (вверх и вправо). Запомни этот угол поворота.
    Потом сожми многоугольник так, чтобы он вписывался в квадрат 1 х 1 единицу. Так как ты работаешь с координатами вершин, а не с пикселями, это не проблема. Запомни, насколько ты сжал многоугольник.
    Теперь, когда ориентация, размер и отношение сторон фрагмента известны, можно сравнивать его с заранее подготовленными профилями фигур - квадратом, кругом, разными треугольниками. Например, находишь разность между значением профиля фигуры и значением профиля фрагмента для этого же направления. Суммируешь эти разности по модулю. Чем меньше сумма - тем более профиль похож.
    Определив наиболее похожую фигуру, растягиваешь её так же, как сжимал многоугольник. Потом поворачиваешь назад на столько же, на сколько повернул многоугольник. Потом смещаешь, чтобы центр фигуры попал на центр масс. Если всё сделано правильно, фигура ляжет "поверх" фрагмента рисовки. Осталось только её обвести тем же цветом.
    С заливкой и перекрытиями будет сложнее, но их можно добавить, оттолкнувшись от этого алгоритма.
    Ответ написан
    Комментировать
  • Как сделать сообщение с фоном в дискорд?

    Vindicar
    @Vindicar
    RTFM!
    Оранжевый фон у сообщений, где есть затрагивающий лично тебя пинг.
    А пометка "спам" вообще отношения к этому не имеет. Вот разве что за излишние пинги можно схлопотать.
    Ответ написан
    Комментировать
  • Как в дискорд сделать обводку сообщения?

    Vindicar
    @Vindicar
    RTFM!
    Этот фон - потому что в сообщении есть пинг, затрагивающий тебя.
    Ответ написан
  • Запуск с определённого места PYTHON?

    Vindicar
    @Vindicar
    RTFM!
    Что значит "запускался с определённой директории"?
    Использовал эту диеркторию в качестве рабочей при запуске? os.chdir()
    Ответ написан
    Комментировать
  • Как распарсить первый 'слой' строки 'struct'?

    Vindicar
    @Vindicar
    RTFM!
    Вообще очень проблематично будет такое распарсить, в том числе регулярками, так как все возможные разделители (в т.ч. "<", запятая, ">") встречаются не по одному разу на разных уровнях. Это задача того же плана, что и "проверить, является ли последовательность скобок корректной (все скобки закрыты, нет закрывающей скобки до открывающей)". Такое решается с помощью конечных автоматов со стеком.
    Код навскидку не приведу - не совсем тривиальная вещь.

    EDIT: вот тебе разбивка на слова, может, поможет.
    def tokenize(line: str):
        token = []
        for ch in line:
            if ch.isalnum() or ch == '_':
                token.append(ch)
            else:
                if token:
                    yield ''.join(token)
                    token.clear()
                yield ch
        if token:
            yield ''.join(token)
    
    data = 'struct<Milk:array<struct<id:string,type:string>>,Oil:string,batter:array<struct<id:string,type:string>>>'
    tokens = list(tokenize(data))
    print(tokens)


    EDIT2: вроде получилось. Спёр идею из одного генератора парсеров - состояние (т.е. конструкция, которую мы обрабатываем) описывается методом класса, стек - стеком вызовов питона, переход из состояния в состояние - вызовом/возвратом из метода.
    Структура данных не совсем та, которая тебе нужна - но её будет куда проще обойти.
    Простыня
    import typing as t
    import enum
    
    
    class Parser:
        @staticmethod
        def tokenize(line: str) -> t.Iterable[str]:
            token = []
            for ch in line:
                if ch.isalnum() or ch == '_':
                    token.append(ch)
                else:
                    if token:
                        yield ''.join(token)
                        token.clear()
                    yield ch
            if token:
                yield ''.join(token)
        
        def process(self, line: str):
            tokens = list(self.tokenize(line))
            result = self.do_type(tokens)
            if tokens:
                raise ValueError('Extra tokens at the end of the line: {0!r}'.format(''.join(tokens)))
            return result
        
        def _consume(self, tokens: t.List[str], expected: t.Optional[str] = None):
            token = tokens.pop(0)
            if expected is not None and token != expected:
                raise ValueError(f'Expected {expected!r}, got {token!r}')
            return token
        
        def do_type(self, tokens: t.List[str]) -> t.Union[str, t.Dict]:
            if tokens[0] == 'struct':
                return self.do_struct(tokens)
            elif tokens[0] == 'array':
                return self.do_array(tokens)
            else:
                return self._consume(tokens)
        
        def do_struct(self, tokens: t.List[str]) -> t.Dict:
            self._consume(tokens, 'struct')
            self._consume(tokens, '<')
            result = {}
            while True:
                name, value = self.do_struct_part(tokens)
                result[name] = value
                if tokens[0] == ',':
                    self._consume(tokens, ',')
                else:
                    break
            self._consume(tokens, '>')
            return result
        
        def do_struct_part(self, tokens: t.List[str]) -> t.Tuple[str, t.Union[str, t.Dict]]:
            name = self._consume(tokens)
            self._consume(tokens, ':')
            value = self.do_type(tokens)
            return name, value
        
        def do_array(self, tokens: t.List[str]) -> t.Dict:
            self._consume(tokens, 'array')
            self._consume(tokens, '<')
            result = { None: self.do_type(tokens) }
            self._consume(tokens, '>')
            return result
    
    
    data = 'struct<Milk:array<struct<id:string,type:string>>,Oil:string,batter:array<struct<id:string,type:string>>>'
    p = Parser()
    print(p.process(data))
    Ответ написан
    Комментировать
  • Как посчитать количество директорий в папке на python?

    Vindicar
    @Vindicar
    RTFM!
    Найти всё, потом для каждого пункта проверить, папка это или нет.
    Либо с помощью pathlib это всё можно реализовать (см. методы в Path), либо с помощью glob.glob() и os.path.isdir().
    Ответ написан
    Комментировать
  • Как данные из большого списка поместить в словарь?

    Vindicar
    @Vindicar
    RTFM!
    1. Делаешь строке .split() по символу перевода строки (\n).
    2. Каждой строке делаешь .partition() по символу ":", получаешь три значения: слева, двоеточие, справа
    3. В словаре используешь значение слева как ключ, значение справа как значение.

    P.S.: Код не проси, тут не невесть как сложно.
    Ответ написан
    1 комментарий
  • Что не так с производительностью pygame и этим кодом?

    Vindicar
    @Vindicar
    RTFM!
    Замерь время выполнения отдельных участков кода через time.perf_counter(), узнай на чем оно задумывается.
    По мне так наиболее вероятные кандидаты - pygame.event.get() и screen.fill().
    Ответ написан
    7 комментариев
  • Проблема с оптимизацией сортировки методом Bubble sort. Как ускорить сортировку для списка из 100 тысяч элементов?

    Vindicar
    @Vindicar
    RTFM!
    start = time.perf_counter()
    bubble_sort(spisok)
    end = time.perf_counter()

    Неужели в голову не пришло, что нужно замерять время как можно ближе к интересующему участку кода?
    Ответ написан
    2 комментария
  • Как сохранить key и value в словаре(dictionary) после завершения работы кода?

    Vindicar
    @Vindicar
    RTFM!
    Сохранить словарь целиком в файл, при запуске программы загрузить из этого файла.
    Если в словаре только примитивы (строки, числа), а также словари и списки, то можно использовать модуль json для этой цели.
    Ответ написан