bildnummern umbenennen nach Regel: n->2n-1
Re: bildnummern umbenennen nach Regel: n->2n-1
heinz' Lösung war die gleiche wie meine. Nur hat er sie "verzehrfertig" serviert, während es bei mir eher ein Kochrezept war.
Re: bildnummern umbenennen nach Regel: n->2n-1
Okay, danke fuer die Erlaeuterung. Die ist gut nachvollziehbar.michaa7 hat geschrieben:15.09.2020 23:11:31Da bin ich der falsche das zu beurteilen.Meillo hat geschrieben:15.09.2020 21:44:20...
Rein interessehalber wuerde mich nur interessieren, *warum* du heinz' Loesung empfehlen kannst. Ist die besser als meine?
Ich habe mir alle Lösungen angeschaut , der Reihe nach (d.h. im wischblick überflogen). Hikarus verlinkte Lösung war ... fragenaufwerfend.
die Lösung von heinz sah ... übersichtlich aus, Seite 1 suggerierte einen Startwert der sich für gerade seiten anpassen ließe (sehe ich dann morgen wenn ich die geraden Seiten abfotografiere), freier Titel implementiert ...
und deine Lösung stand erst weiter unten. . Zudem war die von heinz gebrauchsfertig zusammengerührt, wie der ketchup )) und vermutlich hätte ich beim pipen doch irgendwas nicht richtig gemacht. Zu deutsch heinz hat mein "ich-möchte-full-service" bedient.
Man hat mich per PM gebeten, dass ich meine Loesung erlaeutere, weil meine Nachfrage den Eindruck erweckt hat, dass ich sie besser finde. Nun, ich finde sie technisch besser, wobei das weniger mit dem vorliegenden Problem zu tun hat als mehr mit Style und so. (Das soll keine Kritik an heinz' Loesung sein, die dir ja genau das geliefert hat, was du gesucht hast, und darum gewissermassen genau richtig war.)
Was ich an meiner Umsetzung mag:
- Die Arbeitsschritte sind klarer getrennt: (1) Um welche Dateien geht es, (2) Dateinamen umbauen, (3) Umbenennungen durchfuehren. Jeder der Schritte kann einfach ausgetauscht werden. Fuer einen Dry-Run (Vorschau) lasse ich einfach das `|sh' weg. Ich kann die Ausgabe der Befehle oder die Liste der Dateien einfacher in eine Datei schreiben und aus ihr lesen. Das alles geht mit heinz' Umsetzung schon auch (z.B. `echo' vor das `mv' schreiben), aber es erfordert Veraenderungen im Befehl und nicht am Anfang oder Ende. Damit ist der Befehl schlechter mit anderen Tools kombinierbar, im Sinne des Pipes-and-Filters-Konzepts. Bei meinem Befehl kann die Ausgabe beispielsweise einfach noch duch z.B. `grep' gefiltert werden, um nur manche Umbenennungen durchzufuehren, das geht bei heinz' Umsetzung nicht.
- Mein Befehl ist besser lesbar (awk-Kenntnisse vorausgesetzt), weil er kuerzer ist und weniger Noise enthaelt. Er besteht nur aus den relevanten Komponenten: die relevanten Dateien, printf, Formatstring fuer den mv-Befehl, bisheriger Dateiname, Nummer des neuen Dateinamens (genau so notiert wie michaa7 das im Threadtitel gemacht hat), sh zur Durchfuehrung. Alles in der Reihenfolge, man muss beim Lesen nicht vor und zurueck springen. (Schwierig sind lediglich `$1' (was `$0' heissen sollte) und `NR' in awk, fuer awk-Programmierer gehoeren die aber zum Standard-Repertoire.)
- Keiner der beiden Befehle kann derzeit mit Whitespace umgehen. In meinem Fall muss man im awk-Befehl Quoting hinzufuegen (und `$0' statt `$1' verwenden), das wird etwas haesslich, darum habe ich es weggelassen; alternativ schreibt man den Befehl in eine awk-Scriptdatei, dann ist es mit dem Quoting einfacher. Bei heinz muss man IFS setzen bzw. eine while-read-Schleife verwenden.
- Keiner der beiden Befehle kann mit Quotes in Dateinamen umgehen. Bei heinz wuerde man es wie beim Whitespace beschrieben loesen. Bei mir ist ein zusaetzlicher gsub-Befehl (global substitute) noetig, der die Quotes escapt. An der Stelle ist meine Umsetzung umstaendlicher.
- Mein Befehl hat keine Probleme mit beliebig vielen Dateinamen, sie werden nach und nach durch die Pipeline geschaufelt. Wenn das Globbing auf zu viele Dateien matcht, kann man es durch ein `find' ersetzen. Bei heinz wird einmal durch das Globbing und zudem beim `for' eine ggf. sehr lange Befehlszeile aufgebaut. Will man das verhindern muss man die Schleife in while-read umbauen.
- Ein Vorteil von heinz' Loesung ist, dass es schwerer ist, andere Befehle als `mv' auszufuehren. In meinem Fall entspricht das Pipen durch `sh' einem `eval' ... und das ist bekanntlich ``evil''. Da muss man etwas mehr achtgeben.
So viel mal als Analyse. Fuer das vorliegende Problem macht es keinen Unterschied. Genereller gesehen finde ich meine Umsetzung in ihrem Charakter orthogonaler und mehr dem Pipes-and-Filters-Ansatz entsprechend, was ihr dessen Vorteile gibt. Das finde ich mehr Unix-like, ist aber auch mehr old-style, wie mir scheint. Letztlich kommt es wohl hauptsaechlich darauf an, wie man denkt und welche Ansaetze man gewohnt ist.
heinz' Umsetzung finde ich nicht schlecht. Es ist nur so, dass ich sie nicht besser finde, und da hatte mich etwas irritiert, dass sie empfohlen worden ist. Nun hat sich ja aber geklaert wie diese Empfehlung zu verstehen war.
Use ed once in a while!
Re: bildnummern umbenennen nach Regel: n->2n-1
Ok, spielen wir mit offenen Karten: Die Nachfrage kam von mir.Meillo hat geschrieben:16.09.2020 07:59:57Man hat mich per PM gebeten, dass ich meine Loesung erlaeutere, weil meine Nachfrage den Eindruck erweckt hat, dass ich sie besser finde.
Das kann ich nachvollziehen ...Meillo hat geschrieben:16.09.2020 07:59:57- Die Arbeitsschritte sind klarer getrennt: (1) Um welche Dateien geht es, (2) Dateinamen umbauen, (3) Umbenennungen durchfuehren. Jeder der Schritte kann einfach ausgetauscht werden. Fuer einen Dry-Run (Vorschau) lasse ich einfach das `|sh' weg. Ich kann die Ausgabe der Befehle oder die Liste der Dateien einfacher in eine Datei schreiben und aus ihr lesen. Das alles geht mit heinz' Umsetzung schon auch (z.B. `echo' vor das `mv' schreiben), aber es erfordert Veraenderungen im Befehl und nicht am Anfang oder Ende. Damit ist der Befehl schlechter mit anderen Tools kombinierbar, im Sinne des Pipes-and-Filters-Konzepts. Bei meinem Befehl kann die Ausgabe beispielsweise einfach noch duch z.B. `grep' gefiltert werden, um nur manche Umbenennungen durchzufuehren, das geht bei heinz' Umsetzung nicht.
... das hier aber nicht. Und ich glaube nicht, dass das an meinen mangelnden awk-Kenntnissen liegt.Meillo hat geschrieben:16.09.2020 07:59:57- Mein Befehl ist besser lesbar (awk-Kenntnisse vorausgesetzt), weil er kuerzer ist und weniger Noise enthaelt. Er besteht nur aus den relevanten Komponenten: die relevanten Dateien, printf, Formatstring fuer den mv-Befehl, bisheriger Dateiname, Nummer des neuen Dateinamens (genau so notiert wie michaa7 das im Threadtitel gemacht hat), sh zur Durchfuehrung. Alles in der Reihenfolge, man muss beim Lesen nicht vor und zurueck springen. (Schwierig sind lediglich `$1' (was `$0' heissen sollte) und `NR' in awk, fuer awk-Programmierer gehoeren die aber zum Standard-Repertoire.)
Im Detail:
1. Kürze um der Kürze willen sehe ich nicht als Zeichen für Codequalität.
2. Wenn du sagst, dass dein Befehl weniger Noise enthält, dann müsstest du den Noise in heinz' Befehl ("irrelevante Komponenten"?) benennen können. Ich sehe keinen. Ich finde es lediglich didaktisch ungeschickt, die Lösung als "Einzeiler" darzustellen.
3. Dass man bei deiner Lösung beim Lesen nicht vor und zurückspringen mus stimmt nicht, denn man muss zumindest die Einsetzungen bei printf machen.
4. $1/$0 und NR: Mag sein, dass das Standardrepertoire von awk ist. Zumindest Ersteres ist auch ohne awk-Kenntnisse Programmierer-Allgemeinwissen. Aber für NR braucht man dann wirklich spezifische Kenntnisse. Das Äquivalent dazu in heinz' Lösung ist das "let". Mag sein, dass das mein Bias ist, aber ich finde das zumindest nicht fordernder als awks NR. Die Funktion von beiden erschließt sich für Unwissende aus dem Aufgabenkontext.
Danke! Das hatte ich noch nicht bedacht.Meillo hat geschrieben:16.09.2020 07:59:57- Mein Befehl hat keine Probleme mit beliebig vielen Dateinamen, sie werden nach und nach durch die Pipeline geschaufelt. Wenn das Globbing auf zu viele Dateien matcht, kann man es durch ein `find' ersetzen. Bei heinz wird einmal durch das Globbing und zudem beim `for' eine ggf. sehr lange Befehlszeile aufgebaut. Will man das verhindern muss man die Schleife in while-read umbauen.
Ok. Dann sind wir wieder einer Meinung.Meillo hat geschrieben:16.09.2020 07:59:57heinz' Umsetzung finde ich nicht schlecht. Es ist nur so, dass ich sie nicht besser finde, und da hatte mich etwas irritiert, dass sie empfohlen worden ist. Nun hat sich ja aber geklaert wie diese Empfehlung zu verstehen war.
Re: bildnummern umbenennen nach Regel: n->2n-1
Also, abschließend muß ich hier jetzt noch folgendes erwähnen.
Das ist ein thread wie er mir Spaß macht. Ich bin ja zugegebenermaßen hier eher einer der Konsumenten, der denjenigen hier, die es können seine Alltagsprobleme auferlegt in der Hoffnung auf schnelle Lösung. Und oft auch genervt und verzweifelt bis hin zu nur mühsam beherrscht aggressiv ist von allem was nicht funktioniert ... was man meinen postings dann auch anmerkt.
Der Fachdiskussion ($0 vs. $1 etc) kann ich nicht folgen, habe sie dennoch durchgelesen (soweit nur warum mir gebrauchsfertiges ganz recht war). Rein vom theoretischen Ansatz (ich nenne es mal Modularität) her gefällt mir was Meillo zu seiner Lösung schreibt. Aber um die Vorteile auch in Anspruch nehmen zu können, geschweige denn sie mit Verstand genießen zu können fehlt es mir an einfachsten bash-basics.
Ich hatte mal begonnen ein bash TUT durchzuarbeiten, das aber wieder beendet, weil bei mir viel stärker hängen bleibt oder sich sogar in den Vordergrund drängt was ich nicht verstehe als was ich nachvollziehen kann. Ich muß immer erst *alles* verstanden haben bevor ich einen Teil davon verwenden kann. Das ist leider sehr unökonomisch und bedarf eines Interesses was meine Anforderungen als User bei Weitem übersteigt.
Natürlich finde ich Hilfe zur Selbsthilfe sinnvoll, aber wie schon mehrfach erwähnt, ich war und bin froh dass es hier auf ein einfaches "so-geht-das" hinausgelaufen ist.
Danke.
Das ist ein thread wie er mir Spaß macht. Ich bin ja zugegebenermaßen hier eher einer der Konsumenten, der denjenigen hier, die es können seine Alltagsprobleme auferlegt in der Hoffnung auf schnelle Lösung. Und oft auch genervt und verzweifelt bis hin zu nur mühsam beherrscht aggressiv ist von allem was nicht funktioniert ... was man meinen postings dann auch anmerkt.
Der Fachdiskussion ($0 vs. $1 etc) kann ich nicht folgen, habe sie dennoch durchgelesen (soweit nur warum mir gebrauchsfertiges ganz recht war). Rein vom theoretischen Ansatz (ich nenne es mal Modularität) her gefällt mir was Meillo zu seiner Lösung schreibt. Aber um die Vorteile auch in Anspruch nehmen zu können, geschweige denn sie mit Verstand genießen zu können fehlt es mir an einfachsten bash-basics.
Ich hatte mal begonnen ein bash TUT durchzuarbeiten, das aber wieder beendet, weil bei mir viel stärker hängen bleibt oder sich sogar in den Vordergrund drängt was ich nicht verstehe als was ich nachvollziehen kann. Ich muß immer erst *alles* verstanden haben bevor ich einen Teil davon verwenden kann. Das ist leider sehr unökonomisch und bedarf eines Interesses was meine Anforderungen als User bei Weitem übersteigt.
Natürlich finde ich Hilfe zur Selbsthilfe sinnvoll, aber wie schon mehrfach erwähnt, ich war und bin froh dass es hier auf ein einfaches "so-geht-das" hinausgelaufen ist.
Danke.
gruß
michaa7
-------------------------------
Menschen ändern gelegentlich ihre Ansichten, aber nur selten ihre Motive. (Oskar Negt)
michaa7
-------------------------------
Menschen ändern gelegentlich ihre Ansichten, aber nur selten ihre Motive. (Oskar Negt)
Re: bildnummern umbenennen nach Regel: n->2n-1
@hikaru: Meillos Lösung ist schon deswegen viel guter weil da awk drin ist . so. (egal ob es was tut, solange das nichtstun mit awk geschieht kann es garnicht falsch sein)
awk ist jedenfalls nen tolles Spielzeug, lohnt sich, sich damit mal etwas in Ruhe zu beschäftigen. Bei awk ist $0 die ganze aktuelle Zeile der Daten, $1 das erste Feld davon.
Wenn Du nen Leerzeichen als Feldtrenner hast und als Eingabedaten nen Dateinamen "datei.txt" ist, spielt das in diesen Fall keine Rolle, ob $0 und $1, beide Felder beinhalten "datei.txt". Hast Du dann aber ne Datei "meine tolle datei.txt" dann passiert evtl Murks, weil in $0 "meine tolle datei.txt" drinsteht und in $1 nur "meine".
Einfach fragen wenn was unklar ist, irgendwer (Meillo ) erklärts sicher gerne ausführlichermichaa7 hat geschrieben:16.09.2020 12:19:49Der Fachdiskussion ($0 vs. $1 etc) kann ich nicht folgen, habe sie dennoch durchgelesen (soweit nur warum mir gebrauchsfertiges ganz recht war).
awk ist jedenfalls nen tolles Spielzeug, lohnt sich, sich damit mal etwas in Ruhe zu beschäftigen. Bei awk ist $0 die ganze aktuelle Zeile der Daten, $1 das erste Feld davon.
Wenn Du nen Leerzeichen als Feldtrenner hast und als Eingabedaten nen Dateinamen "datei.txt" ist, spielt das in diesen Fall keine Rolle, ob $0 und $1, beide Felder beinhalten "datei.txt". Hast Du dann aber ne Datei "meine tolle datei.txt" dann passiert evtl Murks, weil in $0 "meine tolle datei.txt" drinsteht und in $1 nur "meine".
Re: bildnummern umbenennen nach Regel: n->2n-1
YMMD!eggy hat geschrieben:16.09.2020 15:01:38@hikaru: Meillos Lösung ist schon deswegen viel guter weil da awk drin ist
... dann lehne ich mich mal zurueck.
Use ed once in a while!
Re: bildnummern umbenennen nach Regel: n->2n-1
Mir war von Anfang an klar, dass sowas kommt:eggy hat geschrieben:16.09.2020 15:01:38@hikaru: Meillos Lösung ist schon deswegen viel guter weil da awk drin ist . so.
hikaru hat geschrieben:10.08.2020 20:47:09Hier kommt bestimmt noch jemand mit einer eleganten awk-Lösung um die Ecke, die im Prinzip das Gleiche macht.
Verstehe! Dann ist awk sowas wie das Gegenstück zu Perl:eggy hat geschrieben:16.09.2020 15:01:38(egal ob es was tut, solange das nichtstun mit awk geschieht kann es garnicht falsch sein)
Perl macht immer $irgendwas, selbst wenn beim Coden nur die Katze über die Tastatur gelaufen ist.
Da fragt sich dann, was passiert, wenn man awk und Perl kombiniert. Implodiert dann das Universum?
Re: bildnummern umbenennen nach Regel: n->2n-1
eggy hat geschrieben:16.09.2020 15:01:38...
Einfach fragen wenn was unklar ist, irgendwer (Meillo ) erklärts sicher gerne ausführlicher
...
Gut, dann mache ich hier schnell weiter bevor ihr unachtsam werdet:
Natürlich stehen alle Bilder Kopf, weil Smartfon, Kamera, Stativ, Platz, Auge, Hand und Umblättern eine Vielzahl von sinnvollen, aber aber auch am Ende kopfstehende Varianten zulassen.
Und lerneifrig wie ich bin habe ich mir zusammengeschustert:
Code: Alles auswählen
ls *.jpg | convert -rotate 180 *.jpg
Also: alle fotos um 180° drehen, namen *nicht* ändern.
(Dass ich ein einzelnes bild mit convert -rotate 180 bild1.jpg bild1.jpg entsprechend drehen kann ist klar. Aber alle bilder durchzuschleußen erfodert nicht vorhandenes Wissen . Ich würde gerne grundsätzlich verstehn wie ich einen bash befehl mit einer schleife kombinieren kann. Schon daran bin ich bei meinem bashstudium gescheitert)
gruß
michaa7
-------------------------------
Menschen ändern gelegentlich ihre Ansichten, aber nur selten ihre Motive. (Oskar Negt)
michaa7
-------------------------------
Menschen ändern gelegentlich ihre Ansichten, aber nur selten ihre Motive. (Oskar Negt)
Re: bildnummern umbenennen nach Regel: n->2n-1
Hier kommen wir zu dem Grund, warum ich es unglücklich finde, dass heinz sein Script als Einzeiler verkauft hat. Dabei geht nämlich mMn die Übersichtlichkeit für dich verloren.
Schreiben wir das "vernünftig" auf, dann sieht es so aus:Wie du siehst, ist da schon eine for-Schleife enthalten. Innerhalb dieser Schleife kannst du convert prinzipiell an beliebiger Stelle einhängen. Am einfachsten wäre es, du machst das vor dem Umbenennen, weil du hier den Dateinamen schon fertig in der Variablen "$datei" hast:
Edit2:
Edit1 zurück. Zu viel Perl heute.
Schreiben wir das "vernünftig" auf, dann sieht es so aus:
Code: Alles auswählen
seite=1
for datei in `ls -1 ./IMG_*`
do
mv "$datei" "f-z-v-t_`printf '%03i' $seite`.jpg"
let seite+=2
done
Code: Alles auswählen
seite=1
for datei in `ls -1 ./IMG_*`
do
convert -rotate 180 "$datei"
mv "$datei" "f-z-v-t_`printf '%03i' $seite`.jpg"
let seite+=2
done
Edit1 zurück. Zu viel Perl heute.
Zuletzt geändert von hikaru am 16.09.2020 16:08:01, insgesamt 1-mal geändert.
Re: bildnummern umbenennen nach Regel: n->2n-1
`convert' erzeugt eine neue Datei mit dem Bearbeitungsergebnis. In-place-Aenderungen macht man mit `mogrify'. Die beiden Befehle koennen das Gleiche nur arbeitet zweiteres eben in-place. Da geht dann sowas wie:
(Auf die anderen Seitenaeste des Themas kann ich gerade zeitlich nicht eingehen, aber in der Sache wollte ich euch nicht in der Luft haengen lassen.)
Code: Alles auswählen
mogrify -rotate 180 *.jpg
(Auf die anderen Seitenaeste des Themas kann ich gerade zeitlich nicht eingehen, aber in der Sache wollte ich euch nicht in der Luft haengen lassen.)
Use ed once in a while!
Re: bildnummern umbenennen nach Regel: n->2n-1
So arbeitet `convert' nicht, es braucht immer Input- und Output-File. Wenn du `convert' durch `mogrify' ersetzt, dann geht es. Einfacher waere aber:hikaru hat geschrieben:16.09.2020 16:01:04Code: Alles auswählen
seite=1 for datei in `ls -1 ./IMG_*` do convert -rotate 180 "$datei" mv "$datei" "f-z-v-t_`printf '%03i' $seite`.jpg" let seite+=2 done
Code: Alles auswählen
for datei in `ls -1 ./IMG_*`
do
convert -rotate 180 "$datei" "f-z-v-t_`printf '%03i' $seite`.jpg"
let seite+=2
done
(Btw: Das `-1' bei `ls' ist nicht noetig. Wenn die Ausgabe nicht auf's Terminal geht, sondern in einen anderen Befehl verhaelt sich `ls' automatisch wie `ls -1'.)
Use ed once in a while!
Re: bildnummern umbenennen nach Regel: n->2n-1
Das tut es perfekt. Danke.Meillo hat geschrieben:16.09.2020 16:06:12`convert' erzeugt eine neue Datei mit dem Bearbeitungsergebnis. In-place-Aenderungen macht man mit `mogrify'. Die beiden Befehle koennen das Gleiche nur arbeitet zweiteres eben in-place. Da geht dann sowas wie:
Code: Alles auswählen
mogrify -rotate 180 *.jpg
(Auf die anderen Seitenaeste des Themas kann ich gerade zeitlich nicht eingehen, aber in der Sache wollte ich euch nicht in der Luft haengen lassen.)
Die Schleifenvariante werde ich mir für das Schleifenstudium vornehmen. Danke auch dafür.
gruß
michaa7
-------------------------------
Menschen ändern gelegentlich ihre Ansichten, aber nur selten ihre Motive. (Oskar Negt)
michaa7
-------------------------------
Menschen ändern gelegentlich ihre Ansichten, aber nur selten ihre Motive. (Oskar Negt)
Re: bildnummern umbenennen nach Regel: n->2n-1
@Meillo: fastMeillo hat geschrieben:16.09.2020 16:06:12Die beiden Befehle koennen das Gleiche nur arbeitet zweiteres eben in-place.
Code: Alles auswählen
diff convert.c mogrify.c |wc
8073 22177 298058
</klugscheissmodus>
Aber ja, in den meisten Fällen kanns das gleiche, nen paar Optionen machen inplace vermutlich keinen Sinn, und wenn ich es richtig in Erinnerung hab, gab es minimale Unterschiede in irgendwelchen super speziellen Sonderfällen, wo man das eine und nicht das andere nehmen musste, aber frag nicht was das war, ist schon ewig her
Und keine Sorge, wir hätten das auch gewusst - Du warst nur mal wieder schneller
@hikaru: awk-perl-Katzen man könnte noch versuchen Butterbrote einzubauen
Re: bildnummern umbenennen nach Regel: n->2n-1
So, nun ist das Thema gegessen:
Habe eben die gradzahligen Seiten abfotografiert. Ging mit Seite 2 los, den Umschlag hatte ich schon gestern per Hand angepasst. Kleiner Stolperstein: Heute von hinten fotografiert, war umblättertechnisch am einfachsten. Schlau wie ich dank euch nun bin führte das zu folgender Befehlszeile:
Thanks.
Habe eben die gradzahligen Seiten abfotografiert. Ging mit Seite 2 los, den Umschlag hatte ich schon gestern per Hand angepasst. Kleiner Stolperstein: Heute von hinten fotografiert, war umblättertechnisch am einfachsten. Schlau wie ich dank euch nun bin führte das zu folgender Befehlszeile:
DONE!seite=2;for datei in `ls -r -1 ./IMG_*`;do mv "$datei" "titel_`printf '%03i' $seite`.jpg";let seite+=2;done
Thanks.
gruß
michaa7
-------------------------------
Menschen ändern gelegentlich ihre Ansichten, aber nur selten ihre Motive. (Oskar Negt)
michaa7
-------------------------------
Menschen ändern gelegentlich ihre Ansichten, aber nur selten ihre Motive. (Oskar Negt)
Re: bildnummern umbenennen nach Regel: n->2n-1
Die Option `--help' ist allerdings auch nur ein undokumentiertes Gimmick. Bei Imagemagick haben alle Optionen nur ein Minuszeichen, also `-help' und `-version', die beide in der Manpage stehen und bei beiden Programmen funktionieren.eggy hat geschrieben:16.09.2020 16:47:47@Meillo: fastMeillo hat geschrieben:16.09.2020 16:06:12Die beiden Befehle koennen das Gleiche nur arbeitet zweiteres eben in-place.mogrify kennt z.B. kein --helpCode: Alles auswählen
diff convert.c mogrify.c |wc 8073 22177 298058
</klugscheissmodus>
Mit `mogrify' kann man das Dateiformat nicht aendern, mit `convert' schon. Das ist wohl der wichtigste Fall. Darueber hinaus kann man bei `convert' getrennte Input- und Output-Optionen haben, z.B. `-density', das IIRC dafuer verwendet werden kann, eine Input-Vektor-Datei gewuenscht genau zu rastern, was dann aber unabhaengig davon ist, wie die Ausgabe-Datei gerastert ist. (Ich meine mich zu erinnern, dass ich das verwendet habe, um PDFs ins PNGs zu konvertieren. Die waren immer zu verpixelt. Die Output-Aufloesung hochzufahren hat nichts gebracht, aber die Input-Density anzupassen schon. So oder so aehnlich war das.) All dies kann `mogrify' nicht. Insgesamt ist `convert' maechtiger, aber `mogrify' ist bequemer wenn man viele Dateien in-place einfach bearbeiten will.Aber ja, in den meisten Fällen kanns das gleiche, nen paar Optionen machen inplace vermutlich keinen Sinn, und wenn ich es richtig in Erinnerung hab, gab es minimale Unterschiede in irgendwelchen super speziellen Sonderfällen, wo man das eine und nicht das andere nehmen musste, aber frag nicht was das war, ist schon ewig her
Ich versuche, euch das naechste Mal mehr Zeit zu geben.Und keine Sorge, wir hätten das auch gewusst - Du warst nur mal wieder schneller
Use ed once in a while!
Re: bildnummern umbenennen nach Regel: n->2n-1
Befehle koennen zwei Arten von Input nutzen:michaa7 hat geschrieben:16.09.2020 15:44:41Und lerneifrig wie ich bin habe ich mir zusammengeschustert:
Code: Alles auswählen
ls *.jpg | convert -rotate 180 *.jpg
1) Kommandozeilenargumente
2) Standardinput
Ersteres sind Woerter, die du hinter den Befehl schreibst (hier: ``-rotate'', ``180'', und alle Dateinamen die die Shell aus ``*.jpg'' expandiert hat).
Zweiteres ist Text, der entweder aus einer Pipe kommt (hier: die Ausgabe von `ls *.jpg'), oder der Inhalt einer Datei, die mit einer Eingabeumleitung `<dateiname' angegeben worden ist, oder ein Here-Dokument (<<MARKER).
Welche Befehle was davon in welcher Weise verarbeiten ist unterschiedlich.
`convert' beispielsweise nimmt die Dateinamen nur als Kommandozeilenargumente entgegen. Standard-Input verarbeitet es gar nicht, ausser der Dateiname im Argument lautet `-', dann wird statt einer per Pfad angegebenen Datei der Dateiinhalt aus Stdin gelesen. (Das machen viele Programme so.)
Die meisten Text-Utilities (grep, wc, cut, ...) lesen die Dateiargumente, oder Stdin wenn keine angegeben sind.
Wenn du dies verstehen willst, dann spiele mit kleinen Textdateien und den Text-Utilities rum. Lerne beispielsweise den Unterschied der beiden Befehle zu erklaeren:
Code: Alles auswählen
:-Q wc *
827 3344 136119 a
603 2763 70941 b
881 5830 303794 c
8282 36429 1845521 d
10593 48366 2356375 total
:-Q cat *|wc
10593 48364 2356375
... oder lass dir weiterhin fertige Ketchup-Loesungen von uns bauen. Wenn die Probleme einfach und spassig sind, bekommst du die frei Haus.
Use ed once in a while!
Re: bildnummern umbenennen nach Regel: n->2n-1
Der Meinung bin ich auch.hikaru hat geschrieben:16.09.2020 10:44:34... das hier aber nicht. Und ich glaube nicht, dass das an meinen mangelnden awk-Kenntnissen liegt.Meillo hat geschrieben:16.09.2020 07:59:57- Mein Befehl ist besser lesbar (awk-Kenntnisse vorausgesetzt), weil er kuerzer ist und weniger Noise enthaelt. Er besteht nur aus den relevanten Komponenten: die relevanten Dateien, printf, Formatstring fuer den mv-Befehl, bisheriger Dateiname, Nummer des neuen Dateinamens (genau so notiert wie michaa7 das im Threadtitel gemacht hat), sh zur Durchfuehrung. Alles in der Reihenfolge, man muss beim Lesen nicht vor und zurueck springen. (Schwierig sind lediglich `$1' (was `$0' heissen sollte) und `NR' in awk, fuer awk-Programmierer gehoeren die aber zum Standard-Repertoire.)
Im Detail:
1. Kürze um der Kürze willen sehe ich nicht als Zeichen für Codequalität.
Leider ist die Frage von Signal und Noise stark vorwissen- und gewohnheitsabhaengig. Ist also `seite = seite + 2' mehr Noise als `seite += 2'? Das zweite Statement sagt kompakter das gleiche aus, also hat es, bei gleichem Signal, weniger Noise. Die Rechnung funktioniert aber nur wenn dem Codeleser beides gleichermassen bekannt und verstaendlich ist.2. Wenn du sagst, dass dein Befehl weniger Noise enthält, dann müsstest du den Noise in heinz' Befehl ("irrelevante Komponenten"?) benennen können. Ich sehe keinen.
Noise kann man reduzieren, wenn man mehr implizite Funktionen der Programmiersprache nutzt, statt die Dinge von Hand zu machen. Darum hat C beispielsweise recht viel Noise. Statt `"foo" + "bar"' muss man dort snprintf(3) und was weiss ich verwenden, Memorymanagement machen, usw. Beides hat die gleiche Aussagekraft, aber im ersten Fall macht die Programmiersprache das Memorymanagement implizit fuer einen. Darum hat der Programmierer weniger Noise in seiner Wahrnehmung.
Ebenso nun hier. In awk spart man sich das Verwalten der Seitennummer, sie muss nicht initialisiert und nicht inkrementiert werden. Stattdessen nutzt man den implizit gefuehrten (vereinfacht gesagt) Zeilenzaehler `NR' (= Number of Record) und wendet darauf eine Funktion (NR*2-1) an. Wie im obigen Beispiel enthaelt der Code auch weniger Noise, weil mehr Logik in den impliziten Bereich verlagert worden ist.
Weniger Noise ist nur dann schlechter, wenn man die impliziten Vorgaenge nicht kennt. Als Anfaenger ist diese Art von Noise ein wichtiges Hilfsmittel, um ueberhaupt zu verstehen was passiert. Da braucht's den einen oder anderen ``Erklaerungssatz'' und mehr Explizites. Je weiter man fortschreitet, desto mehr Implizites will man haben, weil das den ganzen unwichtigen Teil aus dem Blickfeld entfernt, so dass nur noch das Relevante und Interessante uebrig bleibt.
Konkret kann man bei heinz' Umsetzung zwei Dinge als mehr Noise sehen: Die explizite Verwaltung von $seite und die explizite Schleife. Die zwei Dinge passieren in meiner awk-Umsetzung impliziter.
Noise ist es halt nur dann, wenn man es zum Verstaendnis nicht braucht. Du brauchst es zum Verstaendnis, ich nicht; darum ist es fuer dich Hilfsmittel, fuer mich aber Noise. Ich habe wohl zu sehr aus meiner Perspektive betrachtet.
Akzeptiert.3. Dass man bei deiner Lösung beim Lesen nicht vor und zurückspringen mus stimmt nicht, denn man muss zumindest die Einsetzungen bei printf machen.
Was du hier schreibst entspricht dem was ich oben schreibe -- es ist vorwissen- und gewohnheitsabhaengig. Da jeder anderes Vorwissen hat und Unterschiedliches gewohnt ist, kommt man zu unterschiedlichen Ergebnissen.4. $1/$0 und NR: Mag sein, dass das Standardrepertoire von awk ist. Zumindest Ersteres ist auch ohne awk-Kenntnisse Programmierer-Allgemeinwissen. Aber für NR braucht man dann wirklich spezifische Kenntnisse. Das Äquivalent dazu in heinz' Lösung ist das "let". Mag sein, dass das mein Bias ist, aber ich finde das zumindest nicht fordernder als awks NR. Die Funktion von beiden erschließt sich für Unwissende aus dem Aufgabenkontext.
Im Uebrigen ist es lustig, dass du Perl programmierst, denn da ist ja die Koenigssprache der impliziten Allmaechtigkeit.
Use ed once in a while!
Re: bildnummern umbenennen nach Regel: n->2n-1
michaa7 hat geschrieben:16.09.2020 17:49:36Habe eben die gradzahligen Seiten abfotografiert. Ging mit Seite 2 los, den Umschlag hatte ich schon gestern per Hand angepasst. Kleiner Stolperstein: Heute von hinten fotografiert, war umblättertechnisch am einfachsten. Schlau wie ich dank euch nun bin führte das zu folgender Befehlszeile:
seite=2;for datei in `ls -r -1 ./IMG_*`;do mv "$datei" "titel_`printf '%03i' $seite`.jpg";let seite+=2;done
Use ed once in a while!
Re: bildnummern umbenennen nach Regel: n->2n-1
Danke!Meillo hat geschrieben:16.09.2020 16:09:28So arbeitet `convert' nicht, es braucht immer Input- und Output-File. Wenn du `convert' durch `mogrify' ersetzt, dann geht es.
Meillo hat geschrieben:16.09.2020 16:09:28Ach, man sollte nicht mal schnell noch posten wollen, wenn man eigentlich keine Zeit hat.
Ich glaube, wir haben hier unterschiedliche Definitionen von "Noise". Für mich ist dein Beispiel kein Noise, denn es wird ja dabei nichts Unnötiges gemacht. Es wird lediglich die Notation länger, was ich nicht als Nachteil sehe.Meillo hat geschrieben:16.09.2020 23:01:08Leider ist die Frage von Signal und Noise stark vorwissen- und gewohnheitsabhaengig. Ist also `seite = seite + 2' mehr Noise als `seite += 2'? Das zweite Statement sagt kompakter das gleiche aus, also hat es, bei gleichem Signal, weniger Noise. Die Rechnung funktioniert aber nur wenn dem Codeleser beides gleichermassen bekannt und verstaendlich ist.
Wenn ich dich richtig verstehe, müsste selbst der Variablenname in seiner Länge Noise enthalten, denn ein Buchsstabe reicht ja auch. In Perl treibt man sowas gern mit anonymen Variablen auf die Spitze, was ich persönlich fürchterlich finde.
Hier gehe ich mit. Um es mal mit einem IT-fremden Vergleich zu verdeutlichen:Meillo hat geschrieben:16.09.2020 16:09:28Noise kann man reduzieren, wenn man mehr implizite Funktionen der Programmiersprache nutzt, statt die Dinge von Hand zu machen. Darum hat C beispielsweise recht viel Noise. Statt `"foo" + "bar"' muss man dort snprintf(3) und was weiss ich verwenden, Memorymanagement machen, usw. Beides hat die gleiche Aussagekraft, aber im ersten Fall macht die Programmiersprache das Memorymanagement implizit fuer einen. Darum hat der Programmierer weniger Noise in seiner Wahrnehmung.
C ist so, als würde man in einer Kochshow nicht nur die Zubereitung des Gerichts demonstrieren, sondern auch den vorangegangenen Einkauf und das anschließende Putzen der Küche. Das sehe auch ich als Noise. Streng genommen dürte man dann auch nicht auf so populäre Tricks wie "wir haben das schon mal vorbereitet" zurückgreifen, denn die "passive Zubereitungszeit" zu komprimieren ist eine implizite Funktion der Kochshow.
Dieses Verlagern in implizite Funktionen geht aber nur mit awk-spezifischem Spezialwissen und gehört in meinen Augen nicht zum Thema "Bilder umbenennen". Daher sollte das auch kein Kriterium zur Bewertung des eigentlichen Themas sein, sondern nur in die B-Note für die Beherrschung des gewählten Lösungswegs eingehen.Meillo hat geschrieben:16.09.2020 16:09:28Ebenso nun hier. In awk spart man sich das Verwalten der Seitennummer, sie muss nicht initialisiert und nicht inkrementiert werden. Stattdessen nutzt man den implizit gefuehrten (vereinfacht gesagt) Zeilenzaehler `NR' (= Number of Record) und wendet darauf eine Funktion (NR*2-1) an. Wie im obigen Beispiel enthaelt der Code auch weniger Noise, weil mehr Logik in den impliziten Bereich verlagert worden ist.
Ich mache das nicht freiwillig. Ich bin nicht mal ein guter Programmierer. Im Grunde bin ich eher ein Exemplar für das Sprichwort: "Beware of programmers carrying screwdrivers!"Meillo hat geschrieben:16.09.2020 16:09:28Im Uebrigen ist es lustig, dass du Perl programmierst, denn da ist ja die Koenigssprache der impliziten Allmaechtigkeit.