• Различия работы requests в Windows и Linux?

    @o5a
    Denis Klimanov, судя по всему они хотят cookies. Можете добавить в запрос для проверки (взять из браузера например - вкладка Headers)
  • Удалить запрещённое слово, но ошибка, как исправить?

    @o5a
    Дмитрий, потому что для message.photo/video нужно использовать message.caption.lower()
  • Какой метод надо использовать?

    @o5a
    Артём Смирнов, судя по ошибке ('Access denied'), похоже, что при создании ключа не выдали нужные права.
    Создайте ключ с нужными правами (можно сразу указывать полный набор прав) и его уже используйте.
  • Можно распечатать лист как map, через kwargs?

    @o5a
    Вадим, чтобы в print передавать **kwargs, он должен поддерживать параметры с такими именами, поэтому так не работает. Возможно видели не **mapped а что-то подобное
    mapped = [f'my_funt_results ({i}) = {v}' for i,v in enumerate(my_funt_results)]
    print(*mapped, sep='\n')
  • Как логичнее дописывать название файла из вывода?

    @o5a
    JRBRO, Зачем вообще эту дополнительную информацию (score, scale, points) писать в название файла. Судя по описанию задачи, они не являются характеризующими, это просто доп. информация. Основной является этот "индекс"/порядковый номер файла: #1.
    Если не хотите делать по-нормальному (объядинять скрипты в один файл/импортировать), то просто и запускайте свои 3 скрипта подряд, 1-й пишет эти
    #1.txt
    #2.txt
    ...

    А последующие дописывают в них информацию, по соответствию этого индекса.
    Так и получится, что в каждом из этих файлов сначала будет блок score, затем допишется scale, затем points.
  • Вывод количества рефералов, ЧЯДНТ?

    @o5a
    Straxd, это просто sqlite позволяет такие вольности там, где не может быть двузначности: при insert явно идут названия таблиц и полей, там не может быть текстовых строк. Поэтому и работает.
    Но лучше вообще эти одинарные кавычки не использовать даже там.
  • Как получить ссылку на объект по его атрибуту?

    @o5a
    Span4ev, у Вас получился хороший пример XY problem, как не надо задавать вопросы: "Как мне укрепить микроскоп, чтобы он не ломался, когда я забиваю им гвозди" ;)

    Хорошо хоть в конце описали свою изначальную задачу - "Отсортировать список с объектами". Так что на будущее лучше старайтесь сначала описать изначальную проблему, которую нужно решить, а потом уже свои (возможно неправильные) методы решения.
  • Как сделать так, чтобы бот отвечал на команду start?

    @o5a
    meburka, судя по всему, установили библиотеку telebot вместо нужной.
    pip uninstall telebot
    pip install pytelegrambotapi
  • Преобразовать из xls в csv python?

    @o5a
    fastym, В самом CSV нет "странных символов". Какую кодировку указывают при сохранении, в той, он и сохраняется.
    Просто если пытаетесь открыть сохраненный CSV через Excel, то учитывайте, что русская версия Excel пытается открыть в кодировке Windows-1251, поэтому Ваш UTF-8 и выглядит как "странные символы".
    как-то так видимо?
    проверка работы

    Но это не значит, что CSV кривой. Это проблема того, что программа, в которой открываете, пытается отобразить в неродной кодировке.

    Если хотите "правильного" отображения именно в Excel, то сохраняйте в кодировке Windows-1251.
  • Почему не записываются данные в бд SQLITE?

    @o5a
    Ипатьев, В SQL как правило указанные без кавычек названия идентификаторов автоматом приводятся к одному регистру, и так уже запрашиваются в базе (например, в Postgres - к нижнему, в Oracle - к верхнему).
    Поэтому если в Pg создать таблицу
    create table UsERs
    то в базе она создастся как users и обращаться к ней надо соответствующе:
    или
    select * from "users"
    или же без кавычек, тогда не важен регистр (т.к. запрос названия без кавычек автоматом конвертирует в "базовый" регистр, хотя бы так
    select * from UsERs
    И при этом нельзя к ней обратиться по явному верхнему регистру, т.к. по факту таблица именно "users".
    select * from "UsERs"
    вызовет ошибку

    Но если таблица создана с явным указанием регистра
    create table "UsERs"
    То обращаться к ней без кавычек уже не получится, только
    select * from "UsERs"

    Про SQLite я честно не уточнял, если так, значит он действительно регистронезависим, и к нему это не применяется. Я скорее говорил про общие принципы SQL баз.
  • Почему не записываются данные в бд SQLITE?

    @o5a
    mrcoldurfuck, если в названиях таблиц/полей не используете верхний регистр, то кавычки там вообще не нужны, чтобы себя не путать, просто пишите их обычным текстом, т.е.
    SELECT money FROM users WHERE user_id = ?

    Кавычки (именно двойные - ") или ` используются из-за того, что SQL регистрозависим, и если явно обзывать таблицу в верхнем регистре, то обращаться нужно четко по имени, для этого и используются кавычки.

    Т.е. если создать таблицу
    CREATE TABLE "Users"

    То при попытке обратиться
    SELECT FROM users
    получим ошибку, т.к. таблицы "users" нет, надо будет писать
    SELECT FROM "Users"
  • Как исправить ошибку вывода данных из Python в Word (docx)?

    @o5a
    RNIKROBOT, 4 параметра потому, что для методов класса первым передается сам экземпляр класса, self, соответственно с Вашими тремя и получается четыре.
    В вашем случае вообще нужен только 1 параметр - сам текст, так что нужно было из данных просто собрать одну строку, например так
    para3=doc.add_paragraph(f'Тогда взлетная масса первого приближения будет: m0={m0} кг')
  • Почему не копируется список внутри класса?

    @o5a
    Span4ev,
    item.open_items = ['item 1', 'item 2']
    Значит я всё таки перезаписываю атрибут класса - open_items?
    Если обращаясь к item.open_items я получаю не пустой список, а sorted_items является ссылкой на open_items. И даже если бы атрибут open_items ссылался на какой-то объект в памяти, отчего тогда sorted_items не ссылается на тот же объект через open_items?

    Изначально оба списка ссылались на один и тот же объект в памяти - этот пусто список []
    self.open_items         = []
    self.sorted_items_2     = self.open_items

    Но после
    item.open_items = ['item 1', 'item 2']
    это изменилось, и open_items стал ссылаться уже на новый объект.
    А sorted_items2 так и остался ссылаться на изначальный пустой список.
    Чтобы не менять привязку к изначальному объекту в памяти, можно было или использовать append, или именно изменить элементы самого списка (а не создавать новый) например так:
    item.open_items[:] = ['item 1', 'item 2']

    С учетом описанной задачи (есть изначальный список, который меняется и из которого потом нужно сформировать сортированный), лучше сделать примерно так (сортированный список просто берем из актуального состояния изначального списка):
    class Items:
    
        def __init__(self):
            self.open_items         = []
    
        @property
        def sorted_items(self):
            # выдаем результат фильтрации/сортировки из данных самого списка
            # для примера просто обратная сортировка
            return sorted(self.open_items, reverse=True)
    
    item = Items()
    item.open_items = ['item 1', 'item 2']
    
    print(item.open_items)
    print(item.sorted_items)
  • Как удалить строку из массива не обладая ID, JSON?

    @o5a
    Durov90, может стоит подучить базовые основы языка? С чего вдруг
    del data[2]
    будет удалять по значению ключа, да еще и вложенному? Если Вы такое пишете, срочно бросайте ботов и читайте учебник.
  • Python sqlite3 как избежать ошибку?

    @o5a
    А что мешало это условие сразу включить в запрос?
    row = cursor.execute("SELECT * FROM moderations WHERE guild_id=? AND name='ban'", (1,  ))

    или параметром, если нужно
    row = cursor.execute("SELECT * FROM moderations WHERE guild_id=? AND name=?", (1,  'ban'))
  • Что делать, если бот, загруженный на платформу, не видит таблиц в базе?

    @o5a
    Борис Алексеев, судя по описанию автора, так и есть.
    yoyoyoyoYOO, в своего бота добавьте инициализацию базы (создание всех нужных таблиц), или же вместе со скриптами базы кладите на сервер и сам файл базы *.db
  • Как добавить нули перед целыми числами?

    @o5a
    Span4ev, Так а куда Вы это форматирование пихаете? Вставляйте как раз в свою питоновскую get_time
    return f'{self.hour:02}', ...
  • Где ошибка в коде?

    @o5a
    Как многие подобные API, он требует авторизации
    https://bittrex.github.io/api/v1-1/doc.html#authen...
    Без авторизации он выдает не json, а страницу с ошибкой (можно и самому увидеть, если открыть ссылку из кода в браузере).
    Т.е. если вкратце, то нужно зарегистрироваться на сайте, получить токен (API key), и по указанному в документации способу сформировать сообщение, а не просто так получить ссылку.
  • При запросе в SQL таблицу, хочу имя интересующего столбца передать переменной, как правильно сделать это?

    @o5a
    DarkiDeuce, через форматирование строки можно подставлять имя столбца и оно будет работать. Но как Вы сами заметили, в нормальной базе такого быть не должно. Эти Ваши подставляемые названия полей по-хорошему должны быть значениями фиксированных полей.
    Как именно менять это уже от задачи зависит. Но могу привести пример.
    Допустим, вы в своей таблице event заводите разные поля под каждый регион:
    event(event_id, event_name, KGL, PGL, MLG, ... )
    Соответственно чтобы выбрать значения приходится прибегать к таким подстановкам названий полей.
    Но вместо этого лучше делать фиксированное поле, которое будет указывать нужное нам значение региона, например region. Т.е. таблица
    event(event_id, event_name, region, value)
    Соответственно для выбора значения события региона KGL будет применяться уже нормальный запрос
    region = "KGL"
    cur.execute("SELECT value FROM event WHERE region = ?", [region, ])
  • Как конвертировать csv в xlsx на python?

    @o5a
    Данил noname, возможно еще неправильно указали разделители (sep=",").
    В русской версии Excel по умолчанию в CSV разделителем является не запятая, а точка с запятой.
    Если указать не тот разделитель, как раз может получиться похожая ситуация. Проверьте точно, какие в файле используются.