Ответы пользователя по тегу Python
  • Как scr=data:image Сохранить в jpg\png?

    Wispik
    @Wispik
    import base64
    
    imgstring = ""
    imgdata = base64.b64decode(imgstring.split('base64,')[1])
    filename = 'some_image.jpg'
    with open(filename, 'wb') as f:
        f.write(imgdata)
    Ответ написан
  • Не могу понять в чём ошибка, что не так?

    Wispik
    @Wispik
    Ошибка потому что блок elif должен быть сразу после блока if. Видимо, когда копировал, не все отступы перенес.
    Решение: начиная со строки agregator = [] и до elif все сдвинуть вправо
    Ответ написан
    Комментировать
  • Почему выдает ошибку?

    Wispik
    @Wispik
    class ItemService:
        def enrich_with_data(self, session: requests.Session, items: list[Item]) -> list[Item]:
            for item in items:
                response = self.repository.get_additional_data(session, item)
                item_info = response.json()['iteminfo']
                item.full_item_name = item_info['full_item_name']
                #print(item.full_item_name)
    
            return items, item.full_item_name

    в return item.full_item_name, что за переменная item? она доступна только в цикле, поэтому и ошибка
    Ответ написан
  • Как получить из json значение поиском по списку?

    Wispik
    @Wispik
    Можно отдельную функцию для поиска сделать:
    lst = {
        "applist": {
            "apps": [{
                "appid": 1941401,
                "name": "ASD"
            }, {
                "appid": 2170321,
                "name": "SDF"
            }, {
                "appid": 1825161,
                "name": "DFG"
            }]
            }
        }
    
    def find_name(appid):
        if res := list(filter(lambda x: x['appid'] == appid, lst['applist']['apps'])):
            return res[0]['name']
        return None
    Ответ написан
  • Почему не работает инлайн кнопка?

    Wispik
    @Wispik
    Потому что
    dp.register_callback_query_handler(accept, lambda call: True)

    обрабатывает все запросы и все что ниже него не будет работать
    Ответ написан
    Комментировать
  • Aiogram 'Can\'t parse keyboard button: field "request_contact" must be of type boolean' в чем проблема?

    Wispik
    @Wispik
    kb.row(KeyboardButton('Когда', 'Помощь'))
    вот тут ошибка, надо так:
    kb.row(KeyboardButton('Когда'), KeyboardButton('Помощь'))
    Ответ написан
    1 комментарий
  • Как написать опросник с вариантами ответа от 0 до 5, что бы условие выполнялось корректно?

    Wispik
    @Wispik
    Надо использовать register_next_step_handler() , вот почитай хотя бы это
    https://habr.com/ru/post/350648/

    Ну и выкинуть глобал из кода куда подальше
    Ответ написан
    4 комментария
  • Не могу решить задачу на подбрасывание монетки, что делать?

    Wispik
    @Wispik
    from random import randint
    
    
    attempts = []
    
    for i in range(10):
        res = []
        while True:
            res.append(randint(0, 1))
            if len(res) >= 3 and (res[-1]==res[-2]==res[-3]):
                break
        s = ''.join(['О' if s else 'Р' for s in res])
        print(f'{s} (попыток: {len(s)})')
        attempts.append(len(s))
    
    print(f'Среднее количество попыток: {sum(attempts) / len(attempts)}.')
    Ответ написан
    1 комментарий
  • Как победить EOFError: EOF when reading a line в python3.8?

    Wispik
    @Wispik
    Раз ты отправляешь код на сайт, которые его тестит, то очевидно что будет ошибка. Откуда input данные получит?
    Ответ написан
  • Как спарсить php network?

    Wispik
    @Wispik
    Так и парсить.
    Делай запрос на /statusUpdate.php
    Ответ написан
    Комментировать
  • Почему программа не записывает данные в CSV файл?

    Wispik
    @Wispik
    Это рабочий код. Посмотри файл members.csv в папке С://users/Anton
    Ответ написан
    Комментировать
  • Почему print не выводит все значения переменной в цикле?

    Wispik
    @Wispik
    if k == 10:
        continue

    При выполнении условия, цикл начинает следующею итерацию и принт соответственно не выполняется
    Ответ написан
    1 комментарий
  • Как отправить сообщение через APScheduler, не передавая аргумент message?

    Wispik
    @Wispik
    Сделай отдельную функцию:
    async def send_random_quote(message_id):
        x= quotes[randint(0,388)]
        await bot.send_message(message_id, x)

    И используй ее:
    scheduler.add_job(send_random_quote,'cron',day_of_week='mon-sun', hour=19,minute=6,kwargs={'message_id':  callback_query.from_user.id})
    Ответ написан
    1 комментарий
  • FastApi StaticFiles не работает?

    Wispik
    @Wispik
    Давно была похожая проблема, на stackoverflow нашел решение, что нужно раздачу статики и апи делать отдельно.
    Вот пример, из моего кода. Здесь без jinja2, но суть та же
    app = FastAPI()
    app_api = FastAPI()
    
    app.mount("/api", app_api)
    app.mount("/", StaticFiles(directory="static", html=True), name="static")
    
    @app.get('/', response_class=HTMLResponse)
    async def main_page():
        return HTMLResponse('index.html')
    
    
    @app_api.post('/login', response_class=JSONResponse)
    async def login(
        username: str = Body(...),
        password: str = Body(...)
    ):
        ...
    Ответ написан
    Комментировать
  • Как дополнять json файл?

    Wispik
    @Wispik
    Чтобы файл не заменялся, надо его сначала прочитать, изменить, а потом записать в файл
    Ответ написан
    Комментировать
  • Как отстортировать CSV по нечисловому значению?

    Wispik
    @Wispik
    Честно уверен, что есть либо какая-то библиотека, либо это просто можно покрасивее сделать. Но на первый взгляд пришла такая мысль (выглядит не очень красиво, зато работает)))
    reader = csv.reader(open("ip.csv"))
    
    def _sort(s):
        if s.lower() == 'last checked':
            return 0
        res = 0
        s = s.split('ago')[0].strip()
        if 'hour' in s:
            _s = s.split('hour')
            res += int(_s[0]) * 60 * 60
            s = _s[1].strip()
        if 'mins' in s:
            _s = s.split('mins')
            res += int(_s[0]) * 60
            s = _s[1].strip()
        if 'min' in s:
            _s = s.split('min')
            res += int(_s[0]) * 60
            s = _s[1].strip()
        if 'secs' in s:
            _s = s.split('secs')
            res += int(_s[0])
        return res
    
    sort_reader = sorted(reader, key=lambda x: _sort(x[7]))
    Ответ написан
    1 комментарий
  • Как исправить "AttributeError: module 'collections' has no attribute 'Iterable'"?

    Wispik
    @Wispik
    Установи старую версию питона. 3.7 подойдет, возможно 3.8, но это не точно
    Ответ написан
    Комментировать
  • Существует ли функция, которая возвращает абсолютно все комбинации значений из списка?

    Wispik
    @Wispik
    itertools.product(iter, repeat=3)
    Ответ написан
    Комментировать