
Предыдущий: >>3327670 (OP)
Литература:
https://ln2.sync.com/dl/cf2c1d070#xq4s328t-xbbjys2z-9r6j7ss7-gf4e9dv6 <-- Книжки, новое собрание
Ещё книжки: https://yadi.sk/d/HQhhsBsq3TVRUq
Тоже книжки: https://yadi.sk/d/tArKKuQu3Kejuq
Анон, вместо того, чтобы без разметки постить код, лучше шарь его через специальные ресурсы:
https://online-python.com/ - листинги и онлайн-запуск
https://ideone.com/ - возможность постить листинги кода и онлайн-запуска, не требует регистрации
https://dumpz.org/ - можно постить листинги, не требует регистрации
https://pastebin.com/ - для листингов, регистрация не обязательна
https://goonlinetools.com/snapshot/share/ - для листингов, без регистрации, но с капчей
#######################################
Вопросы-ответы:
— С чего начать изучать питон?
У питона намного лучше официальная документация, чем у большинства других языков. Есть там и учебное пособие для начинающих: https://docs.python.org/3/tutorial/introduction.html , неофициальный перевод на русский язык: https://digitology.tech/docs/python_3/tutorial/introduction.html (для питона версии 3.8, но разницы почти нет)
https://github.com/yakimka/python_interview_questions - интересная подборка, масса разнообразных тем и вопросов, для продолжающих, всё на русском
— Какие книги считаются лучшими?
На слуху чаще всего Лутц, но там очень много воды. Ещё на слуху Марк Саммерфильд, Эл Свейгарт "Автоматизация рутинных задач с помощью python". Эти книги рекомендуют чаще всего, но книги довольно старые, а питон развивается.
— Есть у кого на примете годный курс лекций по алгоритмам? Формат лекций мне как-то ближе, нежели просто чтение книги.
МФТИшный курс, например, https://www.youtube.com/playlist?list=PLRDzFCPr95fK7tr47883DFUbm4GeOjjc0
— А как учить джангу? Нахожу книги по джанге 1.х, можно их использовать?
У джанги отличные доки (одни из лучших для пистоновских либ, имхо), почитай их для начала. Книгу по джанге можно читать даже для версий 1.x, т.к. принципы остаются теми же. Но лучше хотя бы с версии 2.0, слишком много мелких изменений в базе.
— Какие веб-фреймворки стоит учить в начале двадцатых?
Что бы не говорили, Джанго живее всех живых и умирать не собирается (и Django REST Framework), очень перспективный асинхронный FastAPI, асинхронный AioHTTP. Flask ещё где-то используется, но уже legacy. Прочие фреймворки или у нас экзотика, или это вымирающее легаси как Торнадо.
— В ньюфаг-треде написано, что нужно начинать с SICP, чтобы научиться программировать
Вот, пожалуйста, та же самая программа, но частично переработанная под язык Python: https://www.composingprograms.com/ (нужно знать ангельский или уметь пользоваться переводчиком)
— Что можно почитать/посмотреть по многопоточности/параллелизации в питоне, да и вообще в целом?
Ролик на американском языке про многопоточность и асинхронность, построение своего event loop с нуля, помогает понять, как устроена асинхронность внутри: https://www.youtube.com/watch?v=MCs5OvhV9S4
— Можно ли на питоне делать мобильные приложения?
Да, смотри на фреймворк Kivy https://en.wikipedia.org/wiki/Kivy_(framework) https://kivy.readthedocs.io но народ на него жалуется
— Как можно без лишней возни ускорить программу на питоне
1) проверь сначала свой код, алгоритмы и структуры данных. Чаще проблема здесь.
2) код можно иногда феерично ускорить, используя JIT (Just-in-Time) компиляцию. Почитай обязательно про модуль numba, он ставится через pip, и альтернативный интерпретатор PyPy.
— Дайте нормальные книжки на русском! Мы, блядь, не в пин##сии живём
Брат, смотри книжки по ссылкам в шапке, там есть и русские. Но помни, без языка ангелов твоя жизнь проходит мимо и ты обречён быть на обочине знаний и технологий.
ps: анон, если ты вносишь изменения в шапку, оставляй ссылку на код с обновлённым исходником.
текущая шапка: https://goonlinetools.com/snapshot/code/#z0o243n8t8byiy2zptv27
То что вам впаривают на курсах - это пиздеж.

>работы на питоне НЕТ. Питон это просто мелкий скриптовый язык, на котором пишется мелкая автоматизация
Подтверждаю.
Инфоцыгане с курсов создали 3к фейковых вакансий.
Ну на бэкенде удалёнке всего 250-300. А остальное там разрознено всё: AQA, DevOps/Sysadmin, Data Science/Data Engineer/DWH.
Ну давай разберем по частям тобою написанное.
1) Убираем нерелевантные слова - data, machine, machine, devops, преподаватель, куратор - чтобы отсеять девопсов, DS, ML и тех, кто ищет наставников для курсов
2) Убираем пункт "Искать в описании вакансии" - питон часто упоминается, как вспомогательный язык стека.
Остается уже не >3к, а всего 733 вакансии. По всем странам, далеко не все они удаленочные. Из них 472 вакансии требуют опыт от 3 лет, для джуномидлов подходят оставшиеся 261 вакансия.
Повторяем процедуру с резюме - 231 тысяча резюме, ищет работу примерно 14% (это можно вычислить по статистике открытых для обычных пользователей резюме), то есть 32 тысячи человек.
123 человека на вакансию.
А теперь проверни подобные операции с любым другим реальным языком промышленной разработки и сравни результаты.
Ищет работу 14к человек.
Количество вакансий с аналогичными фильтрами: 1180. 12 человек на место. Чувствуешь разницу?
Хуйню не неси. В джаве такой же уровень конкуренции. Если хочешь поменьше конкуренцию, то надо в девопс/1с/qa стартовать.
Я тебе сейчас с цифрами доказал, что уровень конкуренции в 9 раз ниже. В Джаве высокая конкуренция, но в отличие от питона есть вакансии и работа, а в петухоне тысячу вкатунов устраивают голодные игры за полторы вакансии.
>тысячи вкатунов
fix
>пишешь на питухоне, страдаешь от динамической лапши 24/7
>обмазываешься аннотациями, постепенно интегрируешь mypy, со временем mypy работает в strict режиме.
Сделал из вашего хуёвого и ебучего питона человека, ну и заодно затерпел и не стал перекатываться на сраное говно. Один лишь вопрос почему эта ваша ебучая нелюдь гвидо не сделает типы обязательными, а динамическую лапшу опциональной, то есть как сейчас, но наоборот?

В 22:00 прием лекарств, не забывай

class SomethingClass(ABC, dict)
В итоге получается так, что я могу создать экземпляр этого абстрактного класса.
Че делать?
Типа, даже если унаследуюсь, то могу вызывать абстрактные методы без их перегрузки. Жижа какая-то выходит.
Абстрактных методов в том виде, как в C++, в питоне нет. При желании ты это можешь реализовать играясь с метаклассами, но вот это нафиг никому не нужно
А вот против вызова таких методов есть стандартный паттерн, ты бросаешь исключение, специально для этого есть NotImplementedError
Ну разве что в джаве ситуация другая, с остальными так же можно всё вывернуть и получить копьё
Да хуйню чел запостил какую-то. Ну 200к резюме с упоминанием питона, какая часть из них вообще активная, а не многолетней давности?
Сейчас на хх есть счетчик откликов в мобильной версии, вот вижу на примере его джавы все те же триста шестьсот шестьсот двести двести откликов на первых рандомных вакансиях. Там еще стажерская свежая висит которую 50 человек смотрит. И кста я исключил из поиска андроид и qa на жабе, получилось столько же вакансий как у него на питон
12 человек на место, больше вакансий, каво нахуй наебать пытается челикью
Меньше всего конкуренция на шарпе, вакансий чуть меньше конечно, но не сильно меньше.

Но только, чтобы всё оффлайн работало, то есть обрабатывалось на моём компе и телефоне.
Я хоть в тот тред попал?
нет , 100% ему кто-то помогает . Мб просто озвучивает текст
Даже смотреть не буду. А ещё КЗОТ запрещает детей нанимать.
А остальные вопросы на ответ?
>разместил его на ВПСе
Фу, челядь ебучая. Нет смысла ради каких-то 1000 запросов в месяц арендовать сервер, он будет 0,00001% времени работать и 99,99999% времени простаивать. Бестолково и неэффективно, тупо переплата за простой.
Что тебе нужно автоматизировать, пидор?
>Бестолково и неэффективно, тупо переплата за простой.
Опять ты, клаудшиз.
Ну и что нынче подходит для телеграм-ботов?
У тебя просто нормальных друзей не было
Как найти классы-дубликаты?
Есть репозиторий с утилитой-кофигуратором.
В ней есть базовый класс BaseDevice и куча потомков вида DeviceFoobar22(BaseDevice), все конфиги хранятся в аттрибутах потомков.
Конфигов много, под 100 штук.
Хочу вывести список потомков-дубликатов, у которых фактически в ТЕКСТЕ КОДА написано одно и тоже, чтобы прописать им наследование от какого-то общего предка и сократить код. (Возможно это пиздец какая плохая идея и лучше не наследоваться вовсе)
Если собрать все классы, взять их аттрибуты (vars), то они будут уникальными, потому что аттрибуты инстанцируются по разным адресам памяти.
Есть какой-то лексический анализатор или другой способ искать избыточные классы-дубликаты?
>Cloudflare, очевидно же.
Бля, уверен что это окажется заманухой. Конторка в принципе гнилая. Лучше уж "VPS друга". Да и сложно это все

>Cloudflare, очевидно же.
Между прочим, что-то новое .
Ты перестал всем рассказывать какой охуенный AWS.
Ждем, когда окончательно образумишься.

"командная строка" - это программа cmd.exe
А ты запустил python.exe и пытается туда пихать команды, которые python не понимает.
мимо-добродвач
>Бля, уверен что это окажется заманухой. Конторка в принципе гнилая. Лучше уж "VPS друга"
Ну и сиди дальше, плати за 99,99999% простоя. Нет смысла тебя переубеждать.
>>78082
Я пользуюсь, меня всё устраивает. Зачем рассказывать если никакой полезной нагрузки в разговоре не будет. Мне влом тратить время на пустое бла-бла, если будет конкретный вопрос по конкретному сервису - то я отвечу.
>Ну и сиди дальше, плати за 99,99999% простоя
Около 0% простоя, поскольку телеграм-бот должен быть поднят всё время, даже если к нему никто не обращается
По логике долбоёба выше нужно отключать тг-бота на ночь, чтоб сэкономить 100 рублей.

400x400, 0:42
PyCharm довольно крут, спору нет, но дорого, а в комунити нет поддержки джанги и поддержка разных sql ограничена.
Может быть на VSCode перемещаться?
Для всего есть vi/vim/emacs. Если ты даже это не осилил, то не утруждай себя программированием.
неужели неочевидно что в этом баяне попугая сзади рукой двигают?
инбифо: накидал тебе за щеку, проверяй
Что такое "основная программа"? Фласк тоже вроде асинхронный. А аутентификацию как прикрутить?
Ты сайт делаешь, либо основной функционал твоей системы не в веб? То есть для чего тебе аутентификация?
На любом фреймворке можно сделать аутентификацию, под любой есть решения соответствующие. Но система же ещё что-то должна делать?
Смысл в том, что функционал интерфейса наверное не самый простой, на этом фоне авторизация лишь небольшая часть. Под это надо фреймворк подбирать. Ещё дальше вопрос в том, как у тебя бэкенд устройством управляет, у тебя синхронные инструменты или asyncio
Если у тебя asyncio-код, то aiohttp удобен, поскольку он построен так, что бы его можешь запускать как отдельный сервис твоей программы, причём можешь запускать, а можешь не запускать. Чаще фреймворки построены так, что всё должно плясать вокруг них, они центральную роль несут, что неудобно.
Короче подумай, какой фреймворк тебе симпатичен, и под него ищи авторизацию. Под любой есть что-нибудь.
Я почитал немного, вижу что в качестве "фронтендов" существуют
- Jupyter Notebook
- JupyterLab
- Какая-то ноутбучная пристройка к вскоду
Что из этого правильнее и/или удобнее юзать?
Спасибо за совет. Поищи, что-нибудь есть, но это не точно. А не проще будет джангу взять? Там оно точно есть и работает изкоробки.
jupyter notebook classic как будто брошенныйю Там серьезные беды с дебаггером. а у меня в wsl там вообще пизда сетевая какая-от.
Так что остается Jupyter Lab
Ну и Vscode, если ты и вправду погроммист.
>правильнее
Молниеносный детект студента или заводчанина.
В ИТ нет правил. Есть выгоды.
Тогда ты будешь постоянно мартышкин труд выполнять.
Ну а созвонами все равно заебут. Без никак вообще.
Я в такой. Небольшая контора, людей немного. Созвон раз в неделю.
Дают задачу и если сам можешь справиться, то можно вообще ни с кем не контактировать. Трекеров нет никаких. Можно работать в любое время, хоть ночью.
Минусы:
код невысокого качества, страдающий от динамики Питона
отсутствие документаций
нулевой онбоардинг
большое разнообразие задач: я и CI настраивал и systemd, и фронтенд, бэкэнд, нагрузочные тесты и ещё кучу всего
все проблемы твои личные по типу проект не можешь запустить, виртуалку настроить, контейнер поднять и т.п.
ЗП меньше 300кк наносек
Пиздец. Разве VSCode нуждается в каких-то советах?
Пиздец блядь, поставь себе нормальную ide. Я знаю только одну: pycharm
Рано или поздно тебе придется писать на других языках. И вот тут то тебе захочется единообразия.
Все норм иде от джетбрейн, на всех языках что мне надо было (жава/до диез/фитон).
>Ок, чем вс код лучше?
Шустрый, куча плагинов, ебически кастомизируется, бесплатно и без повесточки.
Во время работы играет путин-хуйло лала лала? Мне похуй на ваши русн епроблемы. Вскод шустрее пучарма?
Откуда ее вызывать, говно санкционное? Софт ему русофобский, фашисту ебаному.
l1=[1,2,3]
l2=['test1','test2','test3']
res = [x for y in zip(l2, l1) for x in y]
Конкретно - зачем нужна конструкция 'x for y in...'

850x372, 0:03
>Пучарм бесплатен
Только обрезок в видео комунити версии. Подойдет, если ты студент или самоучка, изучающий пиструн.
За нормальную версию у тебя попросят $199 за первый год (потом чуток дешевле).
Ну и чем Pycharm лучше VSCode, чтобы за него $200 отдавать? Просто ЧТО там такого, чего нет в VSCode и за что нужно платить ебаному кабану, чтобы он еще больше распух от денег? который к тому же еще и ренегат, а посему идёт нахуй

>Конкретно - зачем нужна конструкция 'x for y in...'
Это то же самое, что на моем пике, но формализованное в виде генератора, который быстрее, моднее и сахарнее.
А zip-объект, в который ты упаковал свои списки содержит примерно такое: ('test1', 1) ('test2', 2) ('test3', 3), то есть, берет из каждого итерирумого объекта по элементу от первого и до того момента, пока не кончится самый короткий из них. Все это упаковывает в набор кортежей.
Я тоже так делаю, когда нужно одновременно проитерироваться сразу по нескольким последовательностям.

Я сейчас читаю про Conda и кажется, что это оптимальный инструмент. Но при этом в проектах на глаза мне чаще попадались requirements.txt. Объясните как оно устроено в профессиональной разработке?
Типичный блядь питон. Есть pip, есть pipenv, есть конда, есть еще дохуя. Поди сука разберись какой из них хороший.
Проект с необходимостью точного воспроизведения окружения - использую reqs.txt и там все пакеты с == точными версиями .
>Чем тебя не устраивает комунити, по пунктам? Обрезок - это VS.
Зачем ты пытаешься в унылый "сам дурак"? Пукчарм камунити - это обрезок, обмылок, который хорошо подходит для чистого Питхона. Стандартная ситуация, когда ты студент или макака на курсах для начинающих. А речь идет именно о тебе.
Если ты реально работаешь, то тебе нужна поддержка баз данных, нужна поддержка фреймворков, вероятно нужна совместная работа. И ты соснешь делать это в своем обмылке.
Я пробовал разные IDE и редакторы, лучше, чем vim, pycharm и vscode - нет. Но vim для красноглазиков, pycharm - хороша только платная версия, в то время как vscode: умеет буквально всё, превосходит по функционалу pycharm, легковесный, с открытым кодом и с намного, намного более развитым сообществом во всех смыслах.
А почему не используется везде, например, Conda? Тем более раз уж она популярна у датасаентистов.
Я ее просто беру как пример, просто потому что она вроде бы все умеет, в том числе устанавливать и сам питон.
И опять же, вот у тебя на пике написано
>а) просто проект
>...
>б) с необходимостью того-то и того-то
Ну а если одновременно присутствуют разные проекты, разные менеджеры же будут конфликтовать между собой. Опять же получается лучше прицеиться к конкретному менеджеру.
Какой сам дурак? Я про мелкомягкую студию.
Я знаю джангистов которые на бесплатном пучарме работали.
> А речь идет именно о тебе.
Что со мной?
Какая еще совместная работа? Ты про VCS?
> vim,
Фубля красноглаз.
Пучарм тоже опенсорс.
Как давно этот vs code выстрелил?
requirements.txt + pip дают самое точное воспроизведение окружения
Собственно не понятно, что ещё надо. Проблема может быть в том, что невозможно создать окружение без конфликтов, когда один модуль хочет одну версию какого-то другого модуля, а другой другую версию этого же модуля.
Особенно стрёмно, когда пидорасы, что модули разрабатывают, тоже хотят точности и указывают зависимость как ==
Но это надо сказать не только питонячья проблема
>мне чаще попадались requirements.txt
Зависимости часто в setup.py запихивают, используют setuptools, но суть в целом та же, там тоже указывается диапазон версий для каждого модуля, как в requirements.txt
Вопрос в том, как разруливать зависимости, когда они конфликтуют, но тут история о том, что модули всё-таки добавляются не так часто, запихивание чего-либо по поводу и без повода в проект это дурная манера очень.
Если ты создаёшь модуль, по хорошему ты очень вдумчиво должен подойти к тому, какие версии в зависимости указывать, на практике даже в профессиональной разработке с этим проблемы бывают. Если ты указал некорректную зависимость, слишком точную, то никакой инструмент не позволит это исправить автоматом.
> Особенно стрёмно, когда пидорасы, что модули разрабатывают, тоже хотят точности и указывают зависимость как ==
Это какие, например?
> Собственно не понятно, что ещё надо. Проблема может быть в том, что невозможно создать окружение без конфликтов, когда один модуль хочет одну версию какого-то другого модуля, а другой другую версию этого же модуля.
Как обходить? Rpc?
>>83423
15-й стандарт. Есть еще pipenv.
dic = {'cat': '15', 'dog': '42', 'fish': '3', 'dog': '1', 'sun': '44', 'fish': '444'}
Его нужно привести к виду:
dic = {'cat': '15', 'dog': ['42', '1'], 'fish': ['3', '444'], 'sun': '44'}
То есть у меня в словаре повторяются ключи с разными значениями, нужно объединить значения по ключу. Как сделать?
если не работает через добавление переменных окружения то переустанови вскод с сбросом настроек и расширений
бля пока рефакторил result = {} проебал в начале бро
Массивы лучше использовать с числами, а если строки без вариантов, тогда лучше вот так:
old_animals = {'cat': '15', 'dog': '42,1', 'fish': '3,444', 'sun': '44'}
new_animals = {}
for key,val in animals:
_ new_ids = list(filter(lambda x: x in dict, val.split(',')))
_ new_animals[key] = ",".join(new_ids)
BoxLayout:
id: root
BoxLayout:
id: box
Button:
id: btn
Положим, я удалил box из root. Как сделать, чтобы btn узнал о том, что его теперь нет в отображении?
У меня подобное удаление в программе это постоянное событие, т.к. используются MDI окна и они скрываются/показываются (соответственно через remove_widget и add_widget). На момент, когда MDI окно скрыто, я хочу удалять mouse_pos события из Window, и когда наоборот окно показывается, хочу событие снова регистрировать. Можно конечно хуй забить, и так работает, но это некрасиво как-то чтоли. Из-за этого нагрузка при движении мышью в окне высокая, т.к. у меня много виджетов имеют бинды к Window.mouse_pos (всякие кнопки и прочая хуйня которая должна при наведении мыши подсвечиваться).

>помогите создать многозначный диктионарь
>ахаха! я вам говны невнятной накидал а вы решаете ухаха! пук
Чатжптун ты? Узнал тебя по шизойдным высерам.
Не знаю что такое киви, судя по всему какой то гуй, но при любом раскладе кнопка или любой другой элемент это объект в дереве, если ты к нему присобачил какие то методы то они вызываются когда он находится в дереве и в нем всплывают какие-то событя, которые ты обрабатываешь. Не совсем понятно что и кому ты собрался сообщать если объект в дереве отсутствует. Если он есть но скрытый/деактивный то обычно события их игнорируют, если в твоей киве или твоей реализации не игнорируют, то ставь проверку аттрибута hidden и возвращай, либо отцепляй события на время скрытия.
Во-первых, как уже сказал анон выше, как в словаре могут поаторяться ключи?
Во-вторых, у вас в питоне что, в стадлибе нету group_by? Серьезно блять?
Для кого ideone придумали?
Если погуглить, может и найтись.
Пучарм может даже может сам создавать венв и ставить модули из requirmeents.tzt
> Если ты реально работаешь, то
> нужна поддержка баз данных
Не нужна. Встроенные эдиторы бд везде говно. 99% знакомых разрабов сидят на бобре, оставшийся 1% анальных рабов жидбрейнс на датагрипе
> нужна поддержка фреймворко
Только и исключительно если ты пишешь на штанге
> нужна совместная работа
Не нужна
При этом ты не написал про remote execution и дебаггер в докере. Ну, охуительно работаешь, братан
> vscode
> умеет буквально всё
Ага, и 90% из этого "всего" сделано через жопу, чем невозможно пользоваться. Про говнодебаггер и обосранный гит я промолчу, это просто ебаный позор
> превосходит по функционалу pycharm
Удивительные истории,
> легковесный
Легковесный только до той поры, пока ты не поставил 40-50 экстеншенов, чтобы нормально работать.
> с открытым кодом и с намного, намного более развитым сообществом во всех смыслах
Да, это же очень важно. Каждый разработчик после рабочего дня собирается контрибьютить в иде, которой пользуется.
Интересно, а почему ты не написал, что VSCode это говнина на электроне с инпутлагом, а пукчарм это нативное приложение?
Активируй венв. Пиздос, ну какие-то базовые концепции работы с консолью же нужно знать
Почему на питухоне нельзя разрабатывать тырпрайз с таким же успехом как на джава-говне-сисярпе?
на винде иначе не бывает. на линуксе заебись
Пчелидзе, на питоне яндекс такси, самокат и авито сделаны. Нахуя ты фантазируешь?
Так твой код не работает, он не сохранит нужный кабану список значений. Можешь проверить.
Короче реально херня вышла - в словаре не может быть одинаковых ключей (я не тестил просто).
В общем, подмогните с такой ситуевиной:
Есть несколько листов вида
x = [cat, 12, sun, 1, fish, 5, cow, 13]
y = [dog, 121, flower, 1, fish, 5, cow, 100]
В этих листах некоторые элементы совпадают. Необходимо все это дело запихнуть в один лист формата:
z = [cat, 12, dog, 121, flower, 1, sun, 1, fish, 5, 5, cow, 13, 100]
Словарь - лучший вариант, но проблема в том, что если из листов сделать словари, потом их замержить, то значение у ключа будет только одно. Например, из вышеуказанного словарь (после мержа) получится примерно такой:
dic = {cat: 12, dog: 121, flower: 1, sun: 1, fish: 5, cow: 100}
А необходимо такой:
dic = {cat: 12, dog: 121, flower: 1, sun: 1, fish: [5, 5], cow: [13, 100]}
Другая проблема в том, что у меня листы генерятся в цикле. Я могу аппендом добавлять данные в новый лист, но как потом его причесать под нужный мне вид {ключ: [значение, значение, значение]}?
У меня такое даже в неовиме работает на pyright это как раз от вскода лангуаге сервер
Я не знаю правильно ли я тебя понял, но сделай примерно вот так:
x = ['cat', '12', 'sun', '1', 'fish', '5', 'cow', '13']
y = ['dog', '121', 'flower', '1', 'fish', '6', 'cow', '100']
merged_list = [x, y]
res_dict = {}
for i in range(0, len(merged_list), 2):
key = merged_list
val = merged_list[i+1]
ext_val = res_dict.setdefault(key, val)
if isinstance(ext_val, list):
ext_val.append(val)
elif ext_val != val:
res_dict[key] = [ext_val, val]
print(res_dict) # {'cat': '12', 'sun': '1', 'fish': ['5', '6'], 'cow': ['13', '100'], 'dog': '121', 'flower': '1'}
https://github.com/microsoft/pyright/blob/main/docs/settings.md
python.analysis.autoImportCompletions [boolean]: Determines whether pyright offers auto-import completions.
Можно мышкой в настройках найти. Или в жсоне CTRL+P Open User Settings (JSON) туда пишешь "python.analysis.autoImportCompletions": true
Нахуя тебе это надо? Ты явно пытаешься решить какую-то другую проблему, так что ее и неси, а не эту хуйню со списками
В общем, есть python скрипт, который циклично выполняет свою задачу. Запускаю его через bat-файл, содержимое которого title (например script) и команда запуска, всё.
В термина выводятся просто принты о ходе выполнения. Скрипт никакого инпута не требует, живёт сам по себе.
Всё работает нормально, но в какой-нибудь рандомный момент скрипт может зависнуть, а заголовок батника меняется на "Выбор script".
И вот я не пойму, что это такое и из-за чего это может возникнуть?
Проблема особо не гуглится.
Может ли быть такое что в PyCharm параллельно висит "проект" этого скрипта и в момент дебага он запускает одноименный (title такой же как и название проекта) процесс, из-за чего основной скрипт виснет? Однако иногда я дебажу параллельно и норм всё.
Google: ideone
Какие ватники, о чём ты? Поставь операционную систему вместо виндуса, должно помочь. Если вдруг нет - в питухоне вроде есть нормальный дебаггер из коробки, расставь брейкпоинты и смотри, чё там лежит в переменных. В виндувсе через ватники и даблклики юзер-инпут ты вряд ли нормально пробросишь (да и печатать что-то в цмд.екзе один хуй мерзко), поэтому операционную систему в любом случае придётся установить.
Это по работе, поэтому систему поменять не вариант.
Сам скрипт работает нормально, и даже в батнике.
Просто в рандомный момент спустя 3 часа или 15 минут меняется заголовок батника на "Выбор..." и всё.
>поэтому систему поменять не вариант.
Ну тогда энжой ё виндус, что тут сказать. Да, виндус - это всегда боль, как только ты пытаешься делать что-то сложнее потреблядства, на которое он и рассчитан - поди отгадай, что у него на этот раз отъебнуло.
Прыщедолбоеб, питон на винде почти нормально работает. Иди нахуй, то есть на прыщи!
>почти нормально работает
Спермодаун, питон на винде это чужеродный портированный с прыщей софт, некрософт его из коробки не поддерживает, нигде ни в каком виде установить не предлагает, зато предлагает дотнет и бобрпшел и прочее свое говно, которое специально создавалось под шинду.
Так что давай проебись отсюда.
Посмотри все места где скрипт заголовок меняет
То есть для тебя скачать инсталлятор это мозговая перегрузка? -15 мозолей штульмана.
Зачем prev? Почему нельзя пройти от первого до предпоследнего и сравнить элемент с последующим?
потому что я нубик и пока не применяю никакие алгоритмы
list это функция стандартной библиотеки
Используй что нибудь типа list_of_nums
Числа лучше сравнивать с числами, и инициализировать переменную как:
prev = -1
либо минимальным числом
Ну и непонятно что тебе дает выявление дубликатов, убирать их из массива это пиздец как неэффективно, надо создать новый отсортированный отфильтрованный массив и все.
тогда незаморачивайся, пиши как понимаешь
> есть python скрипт, который циклично выполняет свою задачу. Запускаю его через bat-файл
Нахуя? В винде есть планировщик заданий. Запускай через него.
Почему у тебя отсутствует подсветка синтаксиса? Используй нормальную иде типа пукчарма. И не используй названия из билтинов питона

> в 2025г не иметь страницы вконтакте)))
Я с гейоси на линух в свое время ушел из за того что эта ос из линукса с человеческим лицом превращена в окукленную версию ios для десктопа. Линукс наоборот из саморазваливающейся хуйни превратился в нормальную операционную систему, с красивыми и функциональными UI. с понятно работающей и единой системой ярлычков и меню (XGD), с контейнерными приложениями .appimage, с протоном который все стимовские (и не только) игры запускает без проблем практически. есть системд демоны (аналог макосных лаунчд) есть фаирвол (которым можно наебать dpi провайдера) есть вайфай-блютус-4g нетворкинг через встроенный нетворкменеджер, есть запоминание сортировки размера расположения каталогов без всяких .DS_Store как в макоси, темные темы на любой вкус и апскейлинг.
Остались конечно и проблемы, но это мелочи по сравнению с тем что пидор очкастый предлагает своим пользователям. Про Windoшс Retard Edition даже вспоминать тошно
Мне впадлу спорить, единственное реальное преимущество линупса сегодня -- это нативный докер. Раньше в принципедокер был только под линукс по сути и сидеть на чем-то кроме него было безумием. Так что я пару лет был вынужден работать с него. Сейчас можно переехать спокойно на wsl с docker desktop'ами и жить не тужить
Хуже, сорт оф датасатанист с облачными вычислениями
Если так, то в чем? Пыха тоже интерпретируемая, но быстрее питона.
> после отключения гила?
Какого отключения? Ты о чем вообще? Фритрединг это эксперементальная фича, которая непонятно когда готова будет
> Почему питон не стал значимо быстрее во всех сценариях
А в каких сценариях, кроме мультитрединга, он даже в теории мог стать быстрее? Ты вообще понимаешь что такое гил?
> Получается, проблема была не в нем?
Про какую нахуй проблему ты говоришь. Разберись сначала что такое гил, а потом вопросы задавай
Если мне нужно передать в метод класса аргумент таким образом как это на втором примере, то как заставить это работать, чтобы явно не писать например d4.roll(4), блядь, ибо смысл класса теряется, хули я могу тогда процедурно писать вообще. Кубики как пример ессесно.
> мне нужно передать в метод класса аргумент
> но не передавать аргумент
Чего блять? Вопрос сформулируй нормально.
И в питоне переменные camelCase'ом не пишут, используют snake_case
numberOfSides => number_of_sides
А вот имена классов уже UpperCamelCase
die => Die
Я бухой, братик. Ща постараюсь.
Условно у нас есть класс:
class Class:
....def __init__(self, some_arg):
........self.some_arg = some_arg
....def my_method(self, some_arg):
........do_something(some_arg)
Создаём его инстанас:
a = Class(x)
При попытке вызвать a.my_method() получаем ошибку того, что нет требуемого позиционного аргумента. Получается инстанс класса не передаёт в метод some_arg, если указать аргумент явно a.my_method(x) то всё работает верно.
Так же вроде бы корректно работает конструкция вида:
....def my_method(self):
........do_something(self.some_arg)
Но вот как реализовать одновременно работу по аргументу, который мы передаём классу инстансу при создании, с возможностью сохранения явной передачи аргумента при вызове метода? Через попытку передавать в аргументы метода self.some_arg или через дополнительную переменную - вылезают ошибки.
И да я ковыряю питон и доки аж 5 час, мне просто нужно написать небольшой (строк на 4000) скриптик на питоне. И желания слушать "обучающий" гундёж на ютубе нет. По этому бест практикс, правильное форматирование кода и нюансы языка мне не ведомы, как-то так.
Так в чём проблема написать так:
....def my_method(self, some_arg = None):
........if some_arg if None:
............some_arg = self.some_arg
........do_something(some_arg)
> Ногил в 13
Какой ногил, это тестовая фича, которая параметром в билде устанавливается
> Во всех.
Значит ты еблан, который не знает что такое гил. Ты бы хоть минимально изучил вопрос, прежде, чем пукать что-то
> Про медленность питона епт.
В скольких компаниях был -- везде переезжали на питон для повышения производительности. А секрет очень прост -- внутри практически всех либ живет чистый си, который ебет даже плюсы по скорости, при этом позволяя разрабатывать раз в 10 быстрее, чем в случае чистого си
>>88332
Тебе уже написали вот тут как можно это решить >>88357
Правда можно написать даже короче, но тут скорее на вкус и цвет
....def my_method(self, some_arg = None):
........some_args = some_args or self.some_args
........do_something(some_arg)
Но ты уверен, что тебе это реально надо? Выглядит как хуйня ради хуйни плюс возможная протечка абстракции
>Какой ногил, это тестовая фича, которая параметром в билде устанавливается
Ну так изучи вопрос, прежде чем базарить. Почему питон не стал значимо быстрее во всех сценариях после отключения гила?
>Значит ты еблан, который не знает что такое гил. Ты бы хоть минимально изучил вопрос, прежде, чем пукать что-то
>Получается, проблема была не в нем? [не в гиле]
>В скольких компаниях был -- везде переезжали на питон для повышения производительности. А секрет очень прост -- внутри практически всех либ живет чистый си, который ебет даже плюсы по скорости, при этом позволяя разрабатывать раз в 10 быстрее, чем в случае чистого си
Заржал.
> Почему питон не стал значимо быстрее во всех сценариях после отключения гила?
Почему после релиза нового чатжпт не упали цены на квартиры в Москве?
Ну т.е. ты не знаешь. Иди книжки почитай какие-нибудь, того же Лутца можешь навернуть для начала.
Ну т.е. ты не знаешь. Иди книжки почитай какие-нибудь, того же Роджаса можешь навернуть для начала.
Для инклюзивности
Почему во многих проектах, таких как Джанго, стали переименовывать ветки из master в main после того, как сдох нигер уголовник и наркоман? До этого 20 лет всем похеру было.
Потому что примерно такого же цвета будут угли, которые останутся от сгоревшей жопы, после использования этого говна
ruff, как существительное, относится к жестко накрахмаленному оборчатому или плиссированному круглому воротнику из ткани, который носили в XVI и XVII веках
Скорее всего что-то типа rust-written fast formatter.
Перестала работать, пишет, что отсутствует несуществующий файл (поиском проходил), что может быть?
Питон обновлял, в архиве программы нету такого файла (infotor_2.py).
Софт: вьювер оффлайн-версии сайтов в sql формате.
https://drive.google.com/file/d/19E8UflBmd8OdGYvWytrX44MpE4DEH7HF/
Всё, разобрался, нужно было переустановить Python и подключить legacy-cgi. Я как понимаю веб-сервер не эмулировался, от этого и ошибки.
Чел... у меня пивной животик, я хочу себе отчётливые шесть кубиков на животе, скажи за сколько я смогу их получить ходя в спортзал? Мне надо шоп прям вырисовывались и тёлки текли. Вот скажи, за какое время они появятся? При том, что у меня была пятёрка по физкультуре и я катался на велике.
6 месяцев
А тебе не по хуй? Написано в доках не лезь, значит не лезь
В питоне ооп как в джаваскрипте, без приватных полей и методов, используй черточки:
self._param1
self._myMethod1()
Сделано так потому что семантическое разделение проще как в реализации так и для программиста более выразительнее на самом деле, ибо позволяет без IDE от жидбреинс видеть что приватное а что нет.
Питон вроде как хотел быть легким простым, но даже несмотря на то что он разжирел тенденции таковы что вместо public private static protected abstract interface будет:
(async) function method(self_object, args...) //public
(async) function name(args...) // static
Бредик не пишем. До приватных полей можно достучаться в любом языке с рефлексией(а это литералли все языки хоть сколько нибудь популярные). Так что если ты немного подумаешь, то задашь вопрос
> Зачем во всех языках так сделано, что до приватных методов все равно можно достучаться?
И ответ такой -- приват/паблик/протект методы это просто пометка для разработчика, не более. Есть одно функциональное назначение у приватных методов -- не допустить случайного переопределения метода в наследнике(допустим у тебя 50 уровней наследования и какой-нибудь метод self.update, который ты написал в своей реализации, может определяться каким-то из классов наследников и ты все сломаешь). Для такого в питоне есть name mangling с двумя нижними подчеркиваниями
Говно, ебало захлопни и сиди тихонько. Ты даже смог осознать о чем я написал. Пиздец, какой наглый вкатун, услышал краем уха какую-то рыготину, извалялся в ней и пришел в питонтред ей размахивать. Попустись
Говно, я же тебя сказал -- ты не понимаешь о чем вообще говоришь. 5 минут в гугле
https://github.com/jwalton/babel-plugin-private-class-fields-to-public
Но я не удивлен, как бы классические 3 пункта, по которым легко поймать за руку долбаеба:
1. Получить доступ к приватным полям нельзя
2. Ну, если уж и можно получить доступ к приватным полям, то чем больше действий нужно предпринять разработчику для получения доступа к приватным полям, тем безопаснее что бы это нахуй не значило код
3. Если ограничение доступов никак с безопасностью, то уж наличие private полей и сложность доступа к ним извне это и есть инкапсуляция
>babel-plugin-private-class-fields-to-public
>There's this TC39 proposal to add private properties to javascript classes, which are "hard private" - you can't access them from other scopes.
Вот же даун, пиздец
В джаваскрипте нет приватных полей, а если бы были как в джаве и пхп ты не можешь к ним обращаться чисто семантически, их нет в публичной области видимости, в этом их смысл.
> В джаваскрипте нет приватных полей
Это троллинг тупостью?
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes/Private_properties#syntax
> если бы были как в джаве и пхп ты не можешь к ним обращаться чисто семантически
В джаве и пхп точно так же обращаться можно
> их нет в публичной области видимости, в этом их смысл.
Нету, а обращаться можно. Как так?
>>90478
Нет, а ты?
Это недо-приват через спецсимвол (решетку)
Чтобы компилятор просто бил по рукам когда вне метода объекта пытаются обращаться к таким полям.
> В джаве и пхп точно так же обращаться можно
Как "точно так же"?
> Это недо-приват через спецсимвол (решетку)
А "недо" потому что тебе не нравится?
> Чтобы компилятор
Ты даже не представляешь насколько глубока кроличья нора в жсе, зачем ты споришь?
> Как "точно так же"?
Точно так же через рефлексию и интроспекцию

Пиздец
Как быть? pyinstaller не захотел переваривать мой скрипт, но подозреваю, что с ним будет подобное, если заставлю

Один раз?
Все-таки осилил фризинг с pyinstaller (эта хуйня не любит мультипроцессинг и нужно вот так в импорте добавлять оный from multiprocessing import Pool, freeze_support )
Стало лучше, теперь вирустотал выдает 5/72
ААА! Вирус! Не кочайти там вирус. Вот смотрите на вирус тотал БолгеносСканерПро показывает что там вирус ТороянНагибатор666
Что ты там продавать собрался, шиз? И зачем для этого тебе exe'шник? Не проще создать какой-нибудь инсталлер для винды или хотя бы батник?
Допустим, есть функция пик1, которая делает действие, но с двумя условиями. Код каждого условия не слишком большой, но уже достаточен, чтобы сделать рефакторинг.
Я могу пойти двумя путями:
1. Под код каждого условия создать две отдельные функции и вынести их в модуль на тот же уровень, что и управляющая функция. Пик 2. Причем тут я добавил нижнее подчеркивание в начало имени новых функций, чтобы показать, что они является "внутренними" и не предназначены для внешнего использования.
2. Сделать почти то же самое, что в предыдущем пункте, но разместить функции внутри самой управляющей функции. Пик 3
Попрошу не обоссывать меня, возможно с очень нубскими вопросами.
Забыл добавить, что в первом варианте меня смущает именно то, что само модуль будет "засорен" разного рода мелкими функциями. А при третьем варианте создается иллюзия кого-то порядка что ли.
Как делать принято обычно и как вы делаете чаще всего?
>пик1, которая делает действие, но с двумя условиями. Код каждого условия не слишком большой, но уже достаточен, чтобы сделать рефакторинг
Я не вижу для этого причины.
>Я не вижу для этого причины.
На самом деле причина есть, код в каждом условии уже довольно объемный и необходимость выделить уже сама навязывается.
Бро, вопрос тут не стоит делать рефакторинг или нет, для этого слишком мало данных. Вопрос стоит в том, как делать рефакторинг правильно из двух предложенных вариантов, ну или пусть с каким-то третьим вариантом.
В моём понимании не существует "правильного рефакторинга". Всё зависит от окружения.
Если у тебя там всего < 500 строк, то фигачь, что угодно вообще.
А если много кода, то зависит от окружающего кода.
Глядя на 3 картинки, я вижу самое понятное на первой.
>А если много кода, то зависит от окружающего кода.
Можешь предположить варианты? Первая часть понятна, что если кода мало, то можно делать как угодно, а если его много какие есть варианты?
Ну закинь код куда-нибудь на гитхаб. Проведём код ревью всем тредом.
Я не знаю, что можно сказать по обрывкам пары функций.
пик 1 делай максимально дотошно буквально чтобы как книгу можно было читать и выноси даже строчки, если оно тому надо
пик 2 можно еще сделать в виде классов общие по схожести функции чтобы еще больше ориентироваться в коде
пик 3 можно укоротить if и сделать строчки вряд тип если не оч напряжно будет выглядеть
пик 4 можно еще сделать возвращаемые типы и документацию к клоассам
такими шагами и работаем это база
Тебе надо сделать две функции вместо одной. У тебя принципиальная ошибка в том, что у тебя в принципе такая функция появилась. Если у тебя в зависимости от параметра функция начинает принципиально разно выполняться, то это две разные функции

440x480, 0:27
>пик 1 делай максимально дотошно буквально чтобы как книгу можно было читать и выноси даже строчки, если оно тому надо
Можешь пожалуйста развернуть мысль по этому примеру? Для меня это выглядит как пиздецовый огород, но судя по всему ты шаришь в этой теме, хотелось бы получить наставления.
Я сам чмо немного, этот тоже прав >>93304
Вот задачу берем простую тип например вывести самое большое число, не кратное 3
На вход похуй какой массив
Описываем словами сначала шаги
"""
Создаем переменную result, даем ей значение -1 тк -1 это обычно принято, что ответа нет в задаче
Сортируем массив по убыванию
По каждому элементу проходим, пока не найдем не кратное трем
Результат равно найденному числу
Вернуть результат
"""
Почти каждое предложение/ шаг - функция. Показываем что принимает и чему присваивается ее результат (создаем - переменные, поэтому не считается за функцию)
"""
Создаем переменную result, даем ей значение -1 тк -1 это обычно принято, что ответа нет в задач
Сортированный массив = Сортируем массив по убыванию(массив)
Первое число не кратное трем = По каждому элементу проходим, пока не найдем не кратное трем(сортированный массив)
Результат равно найденному числу
Вернуть результат
"""
Переводим в английский, сокращая название чтобы не было тотальный пиздец в 40 символов + обьявлем переменные
"""
result = -1
sorted_massive(array) = sorting_array(array)
first_not_for_three = find_first_not_for_free(sorted_massive)
result = first_not_for_free
return result
"""
В итоге у нас появилось тело алгоритма рабочего, но нужно сделать еще 2 функции низшего уровня
sorting_array(array) и find_first_not_for_free(sorted_massive)
Там также описываешь что она должна делать
sorting_array(array) тут в питоне можно сразу sorted() или .sort() юзануть ТК язык позволяет, в других языках надо алгоритм подробнее описывать тк там нет такого и руками надо сортировать
В find_first...(Sorted_massive)
Берем элемент
Если он не кратен 3 то return элемент
Как-то так извиняюсь за говнокодьместами
Я сам чмо немного, этот тоже прав >>93304
Вот задачу берем простую тип например вывести самое большое число, не кратное 3
На вход похуй какой массив
Описываем словами сначала шаги
"""
Создаем переменную result, даем ей значение -1 тк -1 это обычно принято, что ответа нет в задаче
Сортируем массив по убыванию
По каждому элементу проходим, пока не найдем не кратное трем
Результат равно найденному числу
Вернуть результат
"""
Почти каждое предложение/ шаг - функция. Показываем что принимает и чему присваивается ее результат (создаем - переменные, поэтому не считается за функцию)
"""
Создаем переменную result, даем ей значение -1 тк -1 это обычно принято, что ответа нет в задач
Сортированный массив = Сортируем массив по убыванию(массив)
Первое число не кратное трем = По каждому элементу проходим, пока не найдем не кратное трем(сортированный массив)
Результат равно найденному числу
Вернуть результат
"""
Переводим в английский, сокращая название чтобы не было тотальный пиздец в 40 символов + обьявлем переменные
"""
result = -1
sorted_massive(array) = sorting_array(array)
first_not_for_three = find_first_not_for_free(sorted_massive)
result = first_not_for_free
return result
"""
В итоге у нас появилось тело алгоритма рабочего, но нужно сделать еще 2 функции низшего уровня
sorting_array(array) и find_first_not_for_free(sorted_massive)
Там также описываешь что она должна делать
sorting_array(array) тут в питоне можно сразу sorted() или .sort() юзануть ТК язык позволяет, в других языках надо алгоритм подробнее описывать тк там нет такого и руками надо сортировать
В find_first...(Sorted_massive)
Берем элемент
Если он не кратен 3 то return элемент
Как-то так извиняюсь за говнокодьместами
А ну и главное помни, что функции, которые ты делаешь в ходе алгоса своего (низшие функции) стоят сверху по коду, поэтому как огород может выглядеть и то не идеально