Python + bash
Если вам часто требуется запускать shell команды из Python-кода, какой способ вы используете?
Самый низкоуровневый это функция os.system(), либо os.popen(). Рекомендованный способ это subprocess.call(). Но это всё еще достаточно неудобно.
Советую обратить своё внимание на очень крутую библиотеку sh.
Что она умеет?
🔸 удобный синтаксис вызова команд как функций
# os
import os
os.system("tar cvf demo.tar ~/")
# subprocess
import subprocess
subprocess.call(['tar', 'cvf', 'demo.tar', '~/'])
# sh
import sh
sh.tar('cvf', 'demo.tar', "~/")
🔸 простое создание функции-алиаса для длинной команды
fn = sh.lsof.bake('-i', '-P', '-n')
output = sh.grep(fn(), 'LISTEN')
в этом примере также задействован пайпинг
🔸 удобный вызов команд от sudo
with sh.contrib.sudo:
print(ls("/root"))
Такой запрос спросит пароль. Чтобы это работало нужно соответствующим способом настроить юзера.
А вот вариант с вводом пароля через код.
password = "secret"
sudo = sh.sudo.bake("-S", _in=password+"\n")
print(sudo.ls("/root"))
Это не все фишки. Больше интересных примеров смотрите в документации.
Специально для Windows💀 юзеров
#libs#linux
📦 Не храните всю графику в приложении
Одна из лучших практик — храните в приложении только простые иконки в векторном формате, а всю растровую графику держите в облаке. Особенно это важно для приложений, которые не могут работать офлайн 🌐
Почему это стоит делать:
🚀 Меньше вес приложения → быстрее установка и обновления
📉 Не тянете лишние ресурсы, которые пользователь никогда не увидит (например, фичи под подпиской или в определённом регионе)
🌍 Можно адаптировать загрузку под регион, тариф или подписку
💰 Гибкость — обновляйте, отключайте или заменяйте контент без релиза
Как хранить изображения правильно:
- Векторные иконки → храним в ресурсах приложения
- Баннеры, иллюстрации, фото → CDN или облако (Firebase Storage, CloudFront, S3 и др.) Для загрузки используйте image loader: Coil, Glide, Picasso и т.д.
Чтобы грузить локальные ресурсы в Android через URL можно использовать адреса (примеры для приложения с именем пакета com.example.myapp):
- По имени ресурса android.resource://com.example.myapp/drawable/my_image
- По числовому ID android.resource://com.example.myapp/2130837504
⚙️ Для Compose Multiplatform пока нет прямой поддержки таких ссылок, но можно расширить любой image loader и добавить обработку собственных URL или типов данных
#android#оптимизация#compose#coil
🚢COIL-подход трансформирует морское образование через международную кооперацию.
Современное морское образование все больше интегрирует цифровые и международные форматы обучения.
В рамках проекта COIL (Collaborative Online International Learning) студенты SUNY Maritime College (США) и Lyceum-Northwestern University (Филиппины) совместно работали над задачами, связанными с планированием рейсов и соблюдением экологических норм.
Проект был ориентирован на применение требований MARPOL (Annex V и VI) и Конвенции по управлению балластными водами, а также принципов устойчивого развития (SDG 14).
Участники анализировали вопросы управления отходами, контроля выбросов и экологической ответственности в реальных операционных сценариях.
Программа сочетала синхронное и асинхронное обучение, моделируя реальные условия работы экипажей в международной среде. Использование цифровых инструментов коммуникации позволило отработать навыки взаимодействия в распределенных командах.
Новая инициатива отражает эволюцию требований к морским специалистам. Помимо технических знаний, ключевыми становятся компетенции в области цифровых технологий, межкультурной коммуникации и устойчивого развития.
Результаты проекта показали рост уверенности студентов в международной работе и понимании регуляторных требований, что подтверждает эффективность подобных образовательных моделей.
Таким образом, COIL-подход становится инструментом подготовки кадров для глобальной морской индустрии.
📌SUNY Maritime College - основан в 1874 г, государственное учебное заведение США, входит в систему State University of New York, принадлежит штату Нью-Йорк.
#maritime#education#COIL#shipping#training
Долго смаковал в ожидании нужного момента и вот посмотрел. Кайф! Вроде и знал всё об истории этой культовой в своё время тусовки, но некоторые факты открылись впервые. И конечно яркий документ эпохи, когда лейблы формировали музыкальную сцену, стимулируя к творчеству и воспитывая вкус у слушателя. Рекомендую всем неравнодушным ⚡
#ministry#revoltingcocks#kmfdm#meatbeatmanifesto#theklf#younggods#cubanate#coil#front242#etc