Ответы пользователя по тегу Python
  • Как спарсить то что находится под br?

    @Wispik
    from bs4 import BeautifulSoup
    
    h = '''
        <div class="searchPersonaInfo">
            <a class="searchPersonaName" href="url">Ник</a>
            <br>
            Алекс
            <br>
            Murmansk
            <img src="img.gif">
        </div>
    '''
    
    soup = BeautifulSoup(h, 'lxml')
    div = soup.find(class_='searchPersonaInfo')
    for s in div.stripped_strings:
        print(s)
    Ответ написан
    Комментировать
  • Есть ли возможность спарсить всплывающее окно которое появляется при наведении курсора?

    @Wispik
    https://sirus.su/api/statistic/tooltip.json
    Сюда делаешь запрос и никакой селениум не нужен
    Ответ написан
    3 комментария
  • Проблема с Telegram API, как решить?

    @Wispik
    Во-первых, если с сервера приходит json, лучше делать не так:
    data = json.loads(response.text)
    а так
    data = response.json()
    а во-вторых, ошибка в том, что в словаре data нет ключа result, ну так сделай print(data) и посмотри, что у тебя в словаре лежит
    Ответ написан
  • Не могу вызвать callback функцию aiogram, что делать?

    @Wispik
    Потому что в кнопке:
    callback_data='video'
    А проверяешь ты почему-то так:
    elif callback.data == 'btn_video':
    Ответ написан
    Комментировать
  • Почему виводит ошибку?

    @Wispik
    bot.send_message(message.chat.id, 'Привет,)
    После привет кавычка не закрыта.
    Это даже подсветка тут на сайте показывает, я уже промолчу про IDE
    Ответ написан
    Комментировать
  • Как scr=data:image Сохранить в jpg\png?

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

    @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
    Можно отдельную функцию для поиска сделать:
    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
    Потому что
    dp.register_callback_query_handler(accept, lambda call: True)

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

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

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

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

    @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
    Раз ты отправляешь код на сайт, которые его тестит, то очевидно что будет ошибка. Откуда input данные получит?
    Ответ написан
  • Как спарсить php network?

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

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

    @Wispik
    if k == 10:
        continue

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

    @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
    Давно была похожая проблема, на 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
    Чтобы файл не заменялся, надо его сначала прочитать, изменить, а потом записать в файл
    Ответ написан
    Комментировать