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
27.03.26 Покровское - Андреевка - Даниловка
Позиционные боевые действия в Днепропетровской зоне безопасности.
Позиции ВС РФ в жилой застройке Андреевки и Даниловки обстреляна с дрона ВСУ. Уточнение зоны контроля ВС РФ в Днепропетровской области.
14:00 47.889146, 36.197578
10:30 47.876300, 36.232817
Источник 21+
Геопривязка
#ru#add
26.03.26 Степногорск - Речное
Активные боевые действия в районе Каменского.
Боевая работа подразделений ВС РФ в населённом пункте Речное и его окрестностях. ВС РФ удерживают под уверенным контролем занятые рубежи по южному берегу реки Конка в районе бывшего Каховского водохранилища.
0:00 47.657223,35.321983
2:50 47.672961,35.319197
Источник https://t.me/Bender_Group1/218
Геопривязка
#ru#add
17.04.26 Купянск - Юбилейный
Позиционные боевые действия в Купянске.
Позиция ВС РФ частом секторе рядом с Юбилейным обстреляна ВСУ.
Боевые действия в 3 км от зоны уверенного контроля ВС РФ. События предположительно март 2026.
49.699130, 37.594947
Источник 21+
Геопривязка
#ru#add
04.02.26 Константиновка - 2-й микрорайон - Центральный - Цинковый
Штурм Константиновки.
Серия авиабомбовых ударов ВКС РФ по позициям ВСУ в районах многоэтажной застройки. Применение авиационных боеприпасов с модулем планирования и коррекции.
Удаление от зоны активных боевых действий от 2 км.
Источник https://t.me/rusich13sho/1405
Геопривязка
#ua#add
@creamy_caprice
Подписаться на канал
@Bahmut_Klehseevka
Чат канала
26.01.26 Константиновка - Новосёловка
Штурм Константиновки.
Успешное поражение после обстрела FPV-дронами ВС РФ бронемашины ВСУ на западе Константиновки.
Удаление от зоны активных боевых действий до 7 км.
Источник https://t.me/yuzhny_front_ZOV/22177
Геопривязка
Геопривязка
#ua#add
@creamy_caprice
Подписаться на канал
@Bahmut_Klehseevka
Чат канала
19.01.26 Константиновка - Центральный
Штурм Константиновки.
После обстрела FPV-дронами ВС РФ бронемашину ВСУ разорвало на части в районе многоэтажной застройки Центральный.
Удаление от мест активных боевых действий около 3 км.
Источник https://t.me/z4lpr/1444
#ua#add
📱@creamy_caprice
21.03.26 Купянск - Юбилейный
Активные боевые действия в Купянске.
Заявлено как движение военнослужащих ВС РФ на западной окраине города. Событие на удаление 3 км от зоны активных боевых действий.
49.69662, 37.59368
Источник https://t.me/operationall_space/10401
Геопривязка
Геопривязка
#ru#add
18.04.26 Гуляйполе - Староукраинка
Активные боевые действия в районе Гуляйполя.
Атака ВСУ механизированной группой в направлении Строукраинки. ВС РФ сожгли оставленный бронеавтомобиль ВСУ около населённого пункта. Боевые действия на разграничении зон контроля.
47.67792, 36.14316
Источник https://t.me/voin_dv/19292
#ua#add
@tlgrmcbot
Qué puede hacer este bot?
Este es el bot oficial de telegramic.org! La gente a menudo me usa para iniciar sesión en el sitio web de Telegramic. Pero puedo hacer más! Si no puede encontrar un contenido de Telegram en Telegramic, ¡puede agregarlo!
Idioma: Inglés
(visto en @BotsGram_cu)
#channels, #search, #index, #bestof, #rating, #reviews, #share, #inline, #explore, #discover, #add, #telegramic, #telegram