• Какая ошибка в коде?

    @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
    Ответ написан
    Комментировать
  • Как подтягивать данные из одной ячейки в другую при соблюдении условий?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Так?
    =VLOOKUP(A1;'Лист2'!$A$1:$B$5;2)

    В общем виде: =VLOOKUP(запрос; диапазон; индекс)
    Если не понятно по синтаксису, то здесь максимально наглядно, что-откуда-куда: https://vlookup.com/google-sheets/vlookup-another-sheet
    Ответ написан
    Комментировать
  • Как связать код Python и GUI на wxPython?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    6717cf333e689297739155.png
    Код
    import wx
    
    class MyFrame(wx.Frame):
        def __init__(self, *args, **kwds):
            kwds["style"] = kwds.get("style", 0) | wx.DEFAULT_FRAME_STYLE
            wx.Frame.__init__(self, *args, **kwds)
            self.SetSize((250, 250))
            self.SetTitle("frame")
    
            sizer_1 = wx.WrapSizer(wx.VERTICAL)
    
            fields = [
                ("Ширина (м)", "a"),
                ("Длина (м)", "b"),
                ("Высота (м)", "h"),
                ("Окно ширина (м)", "o1"),
                ("Окно высота (м)", "o2"),
                ("Дверь ширина (м)", "d1"),
                ("Дверь высота (м)", "d2"),
            ]
    
            # Create grid sizers and controls dynamically
            for label_text, attr in fields:
                grid_sizer = wx.GridSizer(1, 2, 0, 0)
                sizer_1.Add(grid_sizer, 1, wx.EXPAND, 0)
    
                label = wx.StaticText(self, wx.ID_ANY, label_text)
                grid_sizer.Add(label, 0, wx.ALL, 1)
    
                text_ctrl = wx.TextCtrl(self, wx.ID_ANY, "")
                setattr(self, attr, text_ctrl)  # Store the text control in the instance
                grid_sizer.Add(text_ctrl, 0, 0, 0)
    
            # Create a horizontal sizer for the result and button
            h_sizer = wx.BoxSizer(wx.HORIZONTAL)
    
            # Result text control
            self.itogo = wx.TextCtrl(self, wx.ID_ANY, "")
            self.itogo.SetBackgroundColour((171, 171, 171))
            h_sizer.Add(self.itogo, 1, wx.EXPAND | wx.ALL, 5)
    
            # Calculate button
            self.button_1 = wx.Button(self, wx.ID_ANY, "Посчитать", size=(110, 21))
            h_sizer.Add(self.button_1, 0, wx.ALL, 5)
            self.button_1.Bind(wx.EVT_BUTTON, self.onclick)
    
            # Add the horizontal sizer to the main sizer
            sizer_1.Add(h_sizer, 0, wx.EXPAND, 0)
    
            self.SetSizer(sizer_1)
            self.Layout()
    
        def onclick(self, event):
            a = float(self.a.GetValue())
            b = float(self.b.GetValue())
            h = float(self.h.GetValue())
            o1 = float(self.o1.GetValue())
            o2 = float(self.o2.GetValue())
            d1 = float(self.d1.GetValue())
            d2 = float(self.d2.GetValue())
    
            result = round(a * 2 * h + b * 2 * h - o1 * o2 - d1 * d2, 2)
            self.itogo.SetValue(str(result))
    
    class MyApp(wx.App):
        def OnInit(self):
            self.frame = MyFrame(None, wx.ID_ANY, "")
            self.SetTopWindow(self.frame)
            self.frame.Show()
            return True
    
    
    if __name__ == "__main__":
        app = MyApp(0)
        app.MainLoop()
    Ответ написан
    1 комментарий
  • Как в tk.Label отобразить содержимое двух списков один над другим?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Речь про Tkinter?
    Если я правильно понял то, что вы хотите:
    l = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
    label_text = '\n'.join(' '.join(map(str, sublist)) for sublist in l)
    label = tk.Label(text=label_text)
    Ответ написан
  • Почему pypsexec не выводит приложение на экран?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    1. Используйте r перед ф-строкой во избежание нескольких invalid escape sequence:
    command = rf'C:\PsTools\psexec.exe -i 1 -s \\192.168.11.18 -u user -p password calc.exe'

    У меня код с subprocess отрабатывает корректно:
    import subprocess
    
    
    def f():
        command = rf'C:\Portable\Sysinternal\PsExec.exe -i 1 -s \\192.168.0.3 -u user -p password calc.exe'
        return subprocess.call(command, stdout=subprocess.DEVNULL)


    2. Вариант с pypsexec у меня отрабатывает некорректно - GUI запускается, но с артефактами.
    Помимо interactive=True, надо указать номер сессии (можно узнать через cmd -> query user), например: interactive_session=1. Это аналог -i 1 в psexec.

    c.run_executable (executable: "cmd.exe", arguments=r"/c start calc.exe", interactive=True, interactive_session=1)
    Ответ написан
    Комментировать
  • Я учу питон, и в данный момент я пытаюсь сделать калькулятор который проверяет данные которые вводит пользователь?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    С одним циклом:
    num_1 = None
    num_2 = None
    effect = None
    
    while True:
        if num_1 is None:
            input_value = input("Введите первое число: ")
            if input_value.isdigit():
                num_1 = int(input_value)
            else:
                print('Вы ввели не число!')
                continue
    
        if num_2 is None:
            input_value = input("Введите второе число: ")
            if input_value.isdigit():
                num_2 = int(input_value)
            else:
                print('Вы ввели не число!')
                continue
    
        if effect is None:
            input_value = input(
                "Напишите что вы хотите сделать (отнять, прибавить, умножить, разделить, возвести в степень, целое деление, остаток от деления): ")
            if input_value in ("+", "-", "*", "/", "**", "//", "%"):
                effect = input_value
                break
            else:
                print('Нету такого действия!')
                continue
    
    # Выполнение операции
    if effect == "+":
        print(num_1 + num_2)
    elif effect == "-":
        print(num_1 - num_2)
    elif effect == "*":
        print(num_1 * num_2)
    elif effect == "/":
        print(num_1 / num_2)
    elif effect == "**":
        print(num_1 ** num_2)
    elif effect == "//":
        print(num_1 // num_2)
    elif effect == "%":
        print(num_1 % num_2)
    Ответ написан
    Комментировать
  • Какое исправление кода помогает на библиотеке disnake для команды translate?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Используйте версию googletrans==4.0.0rc1. Как я понял, в 3.0.0. больше не работает получение токена от Google Translate из-за чего перевод не осуществляется.
    67158d6c97f62379401811.png
    Ответ написан
    Комментировать
  • AttributeError: 'str' object has no attribute 'send' как отправлять юзеру в лс сообщение по ид?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Очевидно потому что config.getint("User", "id") возвращает тип int, а у данного типа нет метода (атрибута) 'send'.
    Следовательно user_id.send("Ваша заявка была одобрена") вызовет ошибку выше.

    Отправлять как-нибудь так:
    user = await bot.fetch_user(user_id: int) 
    await user.send(message)
    Ответ написан
    Комментировать
  • Переменные на кирилице?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    Никак не влияет.
    Нравится, удобно - пишите. Особенно, если не планируете что ваш код будут использовать/поддерживать иностранцы.
    Ответ написан
    3 комментария
  • Графические интерфейсы на Python, какие библиотеки использовать?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    remi.
    Ответ написан
    Комментировать
  • Как подключить видеокарту?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    1. Поставить CUDA.
    2. Проверить:
    import torch
    torch.cuda.is_available()

    3. Перенести модель на GPU:
    device = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
    print(device)
    model = MyModel(args)
    model.to(device)


    От IDE не зависит. Torch Start Locally.
    Ответ написан
    Комментировать
  • Почему в данном примере запуска потока с переданным аргументом, есть разница между способом передачи аргумента?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    В любом замыкании в Python переменные связываются по имени.
    l = []
    for i in range(3):
        l.append(lambda: i)
    print([f() for f in l])
    >>> [2, 2, 2]


    Выход из ситуации — создание отдельной функции или передача аргументов по их имени:
    l = []
    for i in range(3):
        l.append(lambda i = i : i)
    print([f() for f in l])
    >>> [0, 1, 2]


    Т.е. это не вопрос в потоках.
    Ответ написан
    Комментировать
  • Как решить проблему с терминалом PyCharm?

    @dim5x
    ЗИ, ИБ. Помогли? Поблагодарите. Отметьте ответом.
    1. Не использовать пробелы в пути.
    2. Или заключить путь c пробелами в двойные кавычки.
    Ответ написан
    Комментировать