V Bolzanu probíhá konference SFSCON (South Tyrol Free Software Conference). Jean-Baptiste Kempf, zakladatel a prezident VideoLAN a klíčový vývojář VLC media playeru, byl na ní oceněn cenou European SFS Award 2025 udělovanou Free Software Foundation Europe (FSFE) a Linux User Group Bolzano‑Bozen (LUGBZ).
Open-source minimalistický trackball Ploopy Nano byl po modelech modelech Classic a Thumb Trackball také aktualizován. Nová verze Nano 2 používá optický senzor PAW3222 a k původně beztlačítkovému designu přidává jedno tlačítko, které ve výchozí konfiguraci firmwaru QMK přepíná režim posouvání koulí. Sestavený trackball nyní vyjde na 60 kanadských dolarů (bez dopravy a DPH).
Github publikoval Octoverse 2025 (YouTube), tj. každoroční přehled o stavu open source a veřejných softwarových projektů na GitHubu. Každou sekundu se připojil více než jeden nový vývojář. Nejpoužívanějším programovacím jazykem se stal TypeScript.
Kit je nový maskot webového prohlížeče Firefox.
Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.5. Přehled novinek s náhledy v oznámení na blogu.
Německo zvažuje, že zaplatí místním telekomunikačním operátorům včetně Deutsche Telekom, aby nahradili zařízení od čínské firmy Huawei. Náklady na výměnu by mohly přesáhnout dvě miliardy eur (bezmála 49 miliard Kč). Jeden scénář počítá s tím, že vláda na tento záměr použije prostředky určené na obranu či infrastrukturu.
Po dvaceti letech skončil leader japonské SUMO (SUpport.MOzilla.org) komunity Marsf. Důvodem bylo nasazení sumobota, který nedodržuje nastavené postupy a hrubě zasahuje do překladů i archivů. Marsf zároveň zakázal použití svých příspěvků a dat k učení sumobota a AI a požádal o vyřazení svých dat ze všech učebních dat.
Úřad pro ochranu hospodářské soutěže zahajuje sektorové šetření v oblasti mobilních telekomunikačních služeb poskytovaných domácnostem v České republice. Z poznatků získaných na základě prvotní analýzy provedené ve spolupráci s Českým telekomunikačním úřadem (ČTÚ) ÚOHS zjistil, že vzájemné vztahy mezi operátory je zapotřebí detailněji prověřit kvůli možné nefunkčnosti některých aspektů konkurence na trzích, na nichž roste tržní podíl klíčových hráčů a naopak klesá význam nezávislých virtuálních operátorů.
Různé audity bezpečnostních systémů pařížského muzea Louvre odhalily závažné problémy v oblasti kybernetické bezpečnosti a tyto problémy přetrvávaly déle než deset let. Jeden z těchto auditů, který v roce 2014 provedla francouzská národní agentura pro kybernetickou bezpečnost, například ukázal, že heslo do kamerového systému muzea bylo „Louvre“. 😀
Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.
#!/bin/bash
avg=$(
sum=0
count=0
while read line; do
sum=$(($sum + $line))
count=$(($count + 1))
echo $(($sum / $count))
done |
tail -1)
echo $avg
Neexistuje nejake krajsie riesenie? Alebo nejaky obecny trik na podobne ulohy?
Trik so
set -- niecov tomto pripade tiez nepomaha. este jedno riesnie bez pipy a tail, ale podobne odporne
avg=$(sum=0
count=0
while read line; do
sum=$(($sum + $line))
count=$(($count + 1))
echo -n " $(($sum / $count))"
done)
echo ${avg##* }
sum=0
count=0
while read line; do
sum=$((sum + line))
count=$((count + 1))
done
avg=$((sum/count))
echo $avg
#!/bin/bash
sum=0
count=0
echo -e "1\n2\n3" |
while read line; do
sum=$((sum + line))
count=$((count + 1))
done
echo $count
avg=$((sum/count))
echo $avg
Takze takto malo vyzerat povodne zadanie. To ze prenasat premenne nejdu viem, ale zaujima ma potom, ci niekto nepozna nejaky elegantnejsi trik ako to obist.
Cele to potrebujem na skript, ktory cez identify (z ImageMagick) si pozistuje velkosti vysku mnoziny obrazkov, a potom vsetky upravi na ich priemernu vysku.
A cele by som to chcel mat zavisle na co najmensej mnozine softwaru. Zatial si vystacim s bashom, sedom a ImageMagickom. A aj bez toho sedu by som sa zaobisiel.
for line in `echo -e "1\n2\n3"` ; do sum=$((sum + line)) count=$((count + 1)) done
sum=0
count=0
while read line; do
sum=$((sum + line))
count=$((count + 1))
done < vstupni_soubor
echo $count
avg=$((sum/count))
echo $avg
for i in `TU SA NIECO ROZBALI`; do ... done
mktemp) nebo použít pojmenovanou rouru (mkfifo). Jinak novější bash dokáže konstrukci for i in `TU SA NIECO ROZBALI` zvládnout pro libovolně velký výsledek. Při práci s čísly se to dá asi tolerovat, ale ...
Cele to potrebujem na skript, ktory cez identify (z ImageMagick) si pozistuje velkosti vysku mnoziny obrazkov, a potom vsetky upravi na ich priemernu vysku. A cele by som to chcel mat zavisle na co najmensej mnozine softwaru. Zatial si vystacim s bashom, sedom a ImageMagickom. A aj bez toho sedu by som sa zaobisiel.Já bych to dělal takhle:
#!/usr/bin/env python
import os, Image
def find_avg_height(filenames):
sum_height = 0.0
for filename in filenames:
im = Image.open(filename)
sum_height += im.size[1] #height
return sum_height / len(filenames)
def change_height(filenames, newheight):
for filename in filenames:
im = Image.open(filename)
ratio = im.size[1] / newheight
new_size = (int(round(im.size[0] / ratio)),
int(round(newheight)))
out = im.resize(new_size, Image.ANTIALIAS)
out.save('n_' + filename)
filenames = os.listdir('.')
avg_height = find_avg_height(filenames)
print 'Average height is', avg_height
change_height(filenames, avg_height)
Je to program, který projde všechny obrázky v daném adresáři, u každého zjistí rozměry a spočítá z nich průměrnou výšku (Pozor na skripty v shellu - celočíselné dělení nestačí). Pak opět projde všechny obrázky a u každého z nich změní velikost tak, aby výška byla ta vypočítaná a poměr stran zůstal. Nový obrázek bude mít na začátku "n_".
ok, a teraz verziu pracujucu s cmdline zadavanim suborov.No když to musí být ...
import sys filenames = sys.argv[1:]
Inak, celociselne delenie v pohode staci, ale ktovie, mozno vie python vygenerovat aj pol pixeluReálná čísla jsou v mém případě potřeba především kvůli výpočtu nové hodnoty šířky (trojčlenkou).
python nebo perl, případně awk. Druhé řešení je použít stdout tak jak jsi to naznačil a nejedná se o žádný trik. Jen bych podotknul, že mi není jasné, proč to tiskneš pořád dokola, aby jsi to použil jen jednou. Třeba takto
avg=$(
echo -e "1\n2\n3" |
(
sum=0
count=0
while read line
do
let sum+=line
let count++
done
[[ $count -gt 0 ]] && echo $((sum/count))
)
)
echo $avgMyslím, že to není až tak obskurní řešení. Obskurní je nepoužít nějaký ze silnějších jazyků
Tiskni
Sdílej: