Задать вопрос
  • Где на самом деле лежит и как называется файл hosts в windows?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Битность программ не совпадает с виндой. 32-битный Notepad++ не видит папку etc, 64-битный - видит.

    Ваша фраза: "новые (относительно) ищет", видимо, говорит о том же.

    В 64-битной версии Windows папка C:\Windows\System32 содержит 64-битные файлы и библиотеки. Однако, если вы запускаете 32-битное приложение, такое как 32-битная версия Notepad++, Windows перенаправляет запросы к этой папке в C:\Windows\SysWOW64, где находятся 32-битные версии библиотек.
    Это означает, что 32-битное приложение не сможет увидеть или получить доступ к файлам в C:\Windows\System32, включая папку etc, если оно пытается открыть ее через стандартный интерфейс.
    Ответ написан
    3 комментария
  • Что не так с sql запросом?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Использование f-строк для вставки данных в SQL запросы может привести к уязвимостям, связанным с SQL-инъекциями. Вместо использования f-строк, рекомендуется применять параметризованные запросы или подготовленные выражения, что позволяет безопасно передавать данные в запросы.
    Ответ написан
    Комментировать
  • VitHybrid не может добавить позиционные эмбеддинги. Что делать?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    from transformers import ViTHybridConfig, ViTHybridModel
    
    configuration = ViTHybridConfig(patch_size=12)
    model = ViTHybridModel(configuration)
    
    configuration = model.config

    print(configuration.patch_size)
    >>>12
    Ответ написан
    Комментировать
  • Как сформировать поиск фразы/слова между определенных слов Python, регулярные выражения?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    /Наименование\s*(.*?)\s*(Maskota|Картина)
    Брать первую группу.
    Ответ написан
    Комментировать
  • Как сделать фон полупрозрачным и размытым в меню трея?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    import sys
    from PySide6.QtWidgets import QApplication, QSystemTrayIcon, QMenu
    from PySide6.QtGui import QIcon, QAction
    from PySide6.QtCore import Qt
    
    
    def create_tray_icon():
        app = QApplication(sys.argv)
    
        tray_icon = QSystemTrayIcon(QIcon("free-icon-mushroom-17845555.png"), app)
    
        # Создаем меню
        tray_menu = QMenu()
        tray_menu.setWindowFlags(tray_menu.windowFlags() | Qt.FramelessWindowHint | Qt.NoDropShadowWindowHint)
        tray_menu.setAttribute(Qt.WA_TranslucentBackground)
    
        # Настройка стиля меню
        tray_menu.setStyleSheet("""
            QMenu {
                background-color: rgba(255, 255, 255, 150);
                border: 1px solid rgba(0, 0, 0, 50);
            }
            QMenu::item {
                padding: 5px 30px;
                margin: 2px;
                border-radius: 5px;
            }
            QMenu::item:selected {
                background-color: rgba(100, 100, 100, 100);  /* Менее яркое выделение */
                color: black;  /* Цвет текста при выделении */
            }
        """)
    
        # Создаем действия
        action_show_message = QAction("Показать сообщение")
        action_quit = QAction("Выход")
    
        tray_menu.addAction(action_show_message)
        tray_menu.addSeparator()
        tray_menu.addAction(action_quit)
    
        action_show_message.triggered.connect(lambda: tray_icon.showMessage("Заголовок", "Это сообщение из трея"))
        action_quit.triggered.connect(app.quit)
    
        tray_icon.setContextMenu(tray_menu)
        tray_icon.show()
    
        sys.exit(app.exec())
    
    
    if __name__ == "__main__":
        create_tray_icon()


    672dc9e2a21c3749067411.png
    Ответ написан
  • PyQt6. Как сохранить изображение QPixmap в файл?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    import sys
    
    from PyQt6.QtGui import QPixmap
    from PyQt6.QtWidgets import QApplication
    
    app = QApplication(sys.argv)
    
    pixmap = QPixmap(r"path/to/your/image.jpg")
    pixmap.save(r"path/to/your/image.jpg", "JPG")
    Ответ написан
    Комментировать
  • Как решить проблему Expected Expression?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    "LIMIT 5 " & _ - ожидает что строка будет продолжена.

    SQLStr = "SELECT cellName as NSector, SUBSTRING(CAST(cellName as CHAR),1,6) as SiteName " & _
                "FROM LNCEL_begin " & _
                "LIMIT 5"

    Разбиения одной инструкции на несколько строк: https://learn.microsoft.com/ru-ru/dotnet/visual-ba...
    Ответ написан
  • Что за способ представления float через 4 byte и int?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    import struct
    
    float_value = 3.50999999
    
    # Преобразуем float в байты
    byte_value = struct.pack('f', float_value)
    
    # Преобразуем байты в целое число
    int_value = int.from_bytes(byte_value, byteorder='little')
    print(int_value)
    Ответ написан
    1 комментарий
  • Как обнаружить и остановиться на первом переносе строки?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    // Извлекаем текст из <p> с учетом переноса строки
    $content = preg_replace_callback(
        '#<p>(.*?)(?:<br>|</p>)#s',
        function ($matches) {
            return $matches[1]; // Возвращаем текст до первого <br> или </p>
        },
        $content
    );
    Ответ написан
    Комментировать
  • Не получается спарсить ссылку с Binance?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Ссылки генерируются динамически: в вашем r.text нет искомых ссылок. Без использования браузера под капотом не получится.

    from playwright.sync_api import sync_playwright
    
    with sync_playwright() as p:
        browser = p.chromium.launch()
        page = browser.new_page()
        page.goto('https://www.binance.com/ru/support/announcement/новые-листинги-криптовалюты?c=48&navId=48&hl=ru')
    
        # Ждем, пока контент загрузится
        page.wait_for_timeout(2000)
    
        # Извлекаем ссылки
        links = page.query_selector_all('a[class="css-1w8j6ia"]')
        for link in links:
            href = link.get_attribute('href')
            if href:
                full_url = f"https://www.binance.com{href}"
                print(full_url)
    
        browser.close()
    Ответ написан
    1 комментарий
  • Как в Гугл таблицах создать кнопку в ячейке, чтобы при нажатии вносилась сегодняшняя дата (или время)?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    0. Через создание своего меню. Будет по нажатию одной кнопки.
    function insertStaticTime() {
      var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
      var currentTime = new Date();
      var formattedTime = Utilities.formatDate(currentTime, Session.getScriptTimeZone(), "dd.MM.YYYY HH:mm");
      
      // Вставляем текущее время в ячейку A1 (можете изменить на нужную ячейку)
      sheet.getRange("A1").setValue(formattedTime);
    }
    
    function onOpen() {
      var ui = SpreadsheetApp.getUi();
      ui.createMenu('Custom Menu')
          .addItem('Insert Current Time', 'insertStaticTime')
          .addToUi();
    }

    1. Если хочется кнопок (не знаю насколько это удобно, есть некоторые сомнения).
    Buttons in Google Sheets: https://spreadsheet.dev/buttons-in-google-sheets
    В качестве скрипта что-нибудь такое:
    function insertCurrentDateTime() {
      var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); // Получаем активный лист
      var currentDateTime = new Date(); // Получаем текущую дату и время
      sheet.getRange('A1').setValue(currentDateTime); // Вставляем дату и время в ячейку A1
    }

    67249d315fb41363471663.png
    Ответ написан
    2 комментария
  • Какая ошибка в коде?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    1. Составные конструкции имеет смысл писать так:
    case f of
        1 : begin 
                R1:=(a*sqrt(3)/4);
                writeln('R1=',' ',R1);
                { что-то ещё... }
            end;

    2. Есть большие сомнение что в R1 после этого: a*sqrt(3)/4) будет integer. Подумайте над этим.

    3.
    program case14;
    var f : integer;
    var a, R1, R2, S: Real; 
    begin
        writeln ('Введите цифру от 1 до 4 включительно!');
        Readln(f);
        Writeln('Введите значение стороны равностороннего треугольника');
        Readln(a);
    case f of
        1:  
            begin
                R1:=(a*sqrt(3)/4);
                writeln('R1=',' ',R1);
                R2:=R1*2;
                writeln('R2=',' ',R2);
                S:=sqr(a)*sqrt(3)/4;
                writeln('S=',' ',S);
            end;
    end;
    end.
    Ответ написан
    3 комментария
  • Как при нажатие на клавишу клавиатуры применять функцию обработчик в pyqt5?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    В цикле создания кнопок сразу их инициализировать, используя метод setShortcutкласса QPushButton, чтобы связать функцию с конкретной клавишей?
    for i in range(10):
        number_i = QPushButton(str(i))
        number_i.setShortcut(keys[i])
        number_i.clicked.connect(lambda i=i: text_input(i))
        but_num.append(number_i)


    То же и для операций:
    but_op = []
    operations = ["+", "-", "*", "/"]
    for op in operations:
        button = QPushButton(op)
        button.setShortcut(QKeySequence(Qt.Key_Plus if op == "+" else Qt.Key_Minus if op == "-" else Qt.Key_Asterisk if op == "*" else Qt.Key_Slash))
        button.clicked.connect(lambda op=op: operations_input(op))
        but_op.append(button)
    Ответ написан
    Комментировать
  • Чем можно заменить программу ArtCAM?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Пользуюсь Vectric Aspire. Пробовал многие, на мой взгляд лучшая (для дома, хобби).
    Ответ написан
    Комментировать
  • Почему не работает код python для телеграмм бота?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Если используете telebot, то не логичнее ли его и импортировать?
    import telebot

    Если по какой-то неведомой причине имя таки должно быть telegram, то импортируйте так:
    import telebot as telegram

    З.Ы. Есть ощущение, что вы запутались в библиотеках, пишите о telebot'e (и используете его тег), а синтаксис от python-telegram-bot. И в интерпретаторах: используете venv, а установили пакеты в global (если судить по диалогу с Balavnik).
    Ответ написан
    Комментировать
  • Как запустить одну и ту же функцию с разными параметрами одновременно?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Использовать multiprocessing?

    from multiprocessing import Process
    
    ...
    if __name__ == '__main__':
        while True:
            processes = []
            processes.append(Process(target=main, args=('https://rust.tm/item/5358808098-0-Shipping%20Container%20Garage%20Door/', 'Shipping Container Garage Door', 60)))
            processes.append(Process(target=main, args=('https://rust.tm/item/5518269987-0-Abyss%20Vest/', 'Abyss Vest', 140)))
            processes.append(Process(target=main, args=('https://rust.tm/item/4136069987-0-Weather%20Large%20Wood%20Box/', 'Weather Large Wood Box', 100)))
    
            for process in processes:
                process.start()
    
            for process in processes:
                process.join()
    
            time.sleep(5)  # Задержка перед следующим циклом
    Ответ написан
    Комментировать
  • Обработка ошибки в telebot, как сделать обработку на ошибку 409?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Так?
    Написать класс, где будете обрабатывать ошибку и передать его в exception_handler при инициализации бота.
    import telebot
    
    
    class ExceptionHandler(telebot.ExceptionHandler):
        def handle(self, exception):
            print('Ооооошибка 409!:', exception)
            return True
    
    bot = telebot.TeleBot('YOUR_API_TOKEN', exception_handler=ExceptionHandler())
    bot.polling(none_stop=True)
    Ответ написан
    1 комментарий
  • Почему парсер не собирает данные и записывает пустые значения?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Есть несколько моментов:
    1. Про длинный кусок кода: он и не будет работать так, как вы хотите, потому что вы передаёте аргумент with_extra_data=True в свою самописную функцию, а в parser.get_flats() - нет. Соответственно он и не парсит дополнительные поля, отсюда и: "пробовала вывести ключи: смотрю, а их там тупо нет".
    Должно быть:
    data = parser.get_flats(deal_type=deal_type, rooms=rooms, with_extra_data=True,  additional_settings={"start_page": page, "end_page": page})


    2. Если вы действительно использовали эти прокси (а не просто привели их для примера), то это бессмысленно - они нерабочие. Прокси из свободного доступа редко долго живут, а тут они вообще из примера на pypi.org / github.

    3. Вёрстка сайтов постоянно изменяется, в том числе и для противодействия парсингу. Текущая версия циана не имеет<span> c текстом "Тип жилья", а именно такой селектор использовался в библиотеке парсера, следовательно он всегда будет отдавать -1 для object_type.

    4. Если вы всё-таки хотите парсить сайт, используя cianparser, то вам нужно внести несколько изменений в файл библиотеки: "Путь до вашего проекта\venv\Lib\site-packages\cianparser\flat\page.py".
    В функцию__parse_flat_offer_page_json__(self)после инициализации словаря page_data, добавить:
    ot = self.offer_page_soup.select_one('[data-name="OfferSummaryInfoItem"] p:nth-of-type(2)').get_text()
    page_data["object_type"] = ot

    и закомментировать строчки:
    # if "Тип жилья" == span.text:
    #     page_data["object_type"] = spans[index + 1].text


    Результат:
    671dbfa43dc32277607933.png
    Ответ написан
    3 комментария
  • Как это сделать в Excel?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Так?
    =REGEXREPLACE(A1; CHAR(10); ";" & CHAR(10))

    6719759bea3ea835827449.png
    Ответ написан
    Комментировать