Задать вопрос
Ответы пользователя по тегу Python
  • Как возвращать промежуточный результат?

    Vindicar
    @Vindicar
    RTFM!
    Перепишите скрипт A так, чтобы он позволял сообщать сведения о прогрессе иначе. Упрощенный пример:

    Было:
    import time
    
    for i in range(100):
        time.sleep(1)
        print($"{i}%")


    Стало:
    import time
    
    def run_script(on_progress):
        for i in range(100):
            time.sleep(1)
            on_progress(i)
    
    if __name__ == '__main__':
        run_script(lambda i: print($"{i}%"))


    Тогда в другом скрипте будет:
    from script_a import run_script
    
    def my_progress(i):
        pass # показываешь прогресс скрипта
    
    run_script(my_progress)


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

    Vindicar
    @Vindicar
    RTFM!
    Не присваивай переменной значение прописанное прямо в коде, а читай его из файла. Если переменная и впрямь одна и она примитивная (число/строка) - можно просто из файла, если их несколько - нужна структура и модуль json, если их много - впору задуматься о БД.
    Ответ написан
    Комментировать
  • Как накладывать изображения в python?

    Vindicar
    @Vindicar
    RTFM!
    Т.е. если переформулировать вопрос:
    Есть два изображения (A и B) с одинаковым набором маркеров. Нужно трансформировать изображение B так, чтобы его маркеры совпали по положению с маркерами изображения A, а потом наложить результат на изображение A.
    Я так понял?

    Если да, то это делается примерно так.
    1. Формируешь два массива координат - маркеры на изображениях A и B. Как - зависит от типа маркеров, но порядок должен быть одинаковым в обоих массивах. Форма (shape) массивов должна быть (N, 1, 2), где последний индекс отвечает за x или y координату, а N - число маркеров.
    2. Вызываешь
    homography, ptmask = cv2.findHomography(arrayB, arrayA, cv2.RANSAC)
    .
    homography будет матрицей проективного преобразования - как повернуть маркеры B, чтобы они легли на маркеры A. ptmask будет содержать сведения о том, какие пары точек удалось совместить.
    3. Делаешь вызов cv2.warpPerspective(), чтобы повернуть изображение B согласно матрице homography. Параметр размера должен быть таким чтобы второе изображение точно уместилось вместе с первым. Например, можно заранее создать большое изображение по размеру.
    4. Делаешь совмещение. Используешь cv2.PerspectiveTransform(), чтобы понять, где на итоговом изображении будут углы изображения B, делаешь cv2.fillPoly() чтобы создать бинарную маску для наложения. В маске белый пиксель будет означать "сюда поместить пиксель из повернутого B", а черный - "оставить пиксель как есть". Используешь эту маску, чтобы выполнить наложение.

    Пример кода и исходных данных - не совсем то, что тебе нужно, но идею передаст, я надеюсь.
    Ответ написан
  • Tkinter grid, как растянуть сетку на все окно?

    Vindicar
    @Vindicar
    RTFM!
    Адаптивность решается через rowconfigure() и columnconfigure().
    А вот сам вопрос кривой: тебе нужно окно на весь экран, или только виджет на всё окно? Это разные вещи, как бы.

    Если нужно растянуть один виджет на всё окно (root), то просто
    widget.pack(fill='both', expand=True)
    Ответ написан
  • Как получить html страницы,который не активен через запросы?

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

    Vindicar
    @Vindicar
    RTFM!
    У тебя внутренний цикл while разбивает одно число. Перед этим циклом создай новый список, и закидывай числа туда, а не в X. После while закидывай этот список в X.
    Ответ написан
    1 комментарий
  • Как решить данную проблему с SQLite?

    Vindicar
    @Vindicar
    RTFM!
    for row in result:
        singup = str(row[0])

    Молчаливо подразумевает, что в result будет хотя бы одна строка. Это далеко не факт.
    Если result пуст, то singup не будет присвоено значение.
    Ответ написан
    Комментировать
  • Как достать значение ключа из словаря?

    Vindicar
    @Vindicar
    RTFM!
    Вообще очень странная конструкция. Если ключи верхнего уровня гарантированно уникальны, проще будет сделать так:
    my_lst = [ ... тут твой список ... ]
    my_dct = {}
    for item in my_lst:
        my_dct.update(item)

    И тогда можно будет просто оперировать my_dct.keys(). Например,
    keys = list(map(int, my_dct.keys()))
    print(f"{min(keys)}...{max(keys)}")
    Ответ написан
    1 комментарий
  • Как удалить временные файлы?

    Vindicar
    @Vindicar
    RTFM!
    Используй модуль tempfile, он умеет прибирать за собой. Но это лучше всего работает, если тебе нужен именно файловый объект, а не именованный файл в файловой системе. Есть, конечно, класс tempfile.NamedTempFile, но там свои заморочки.
    Ответ написан
    Комментировать
  • UnboundLocalError: local variable referenced before assignment что делать?

    Vindicar
    @Vindicar
    RTFM!
    Если цикл for block in soup.find_all не выполнится ни разу (например, нет подходящих элементов), то task_stack не будет присвоено значение. А ты дальше его читаешь.
    Предусмотри какое-то значение по умолчанию для этой переменной, и проверяй такой случай.
    Ответ написан
    Комментировать
  • Нажимаю на кнопку она не работает, при этом схема собрана правильно, Что не так с кодом?

    Vindicar
    @Vindicar
    RTFM!
    Проверь документацию, может, номер пина не тот? Номер бита в регистре цифрового ввода вывода - это не то же самое, что номер пина на плате.
    И я без понятия, какую нумерацию использует питоновская обертка. Но судя по отсутствию указания модели платы в коде, вряд ли номер пина на плате...
    Ответ написан
    Комментировать
  • Как реализовать систему изменения данных в базе данных?

    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 есть применения.
    Ответ написан
    Комментировать
  • Как выводить сообщение без остановки?

    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)  # запускаешь бота
    Ответ написан
    Комментировать
  • Как сделать цикл не задерживающий программу в Python?

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

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

    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))
    Ответ написан
    Комментировать