Hyæna

Through the darkness of future past

Terminal: Umbenennen vieler Dateien mit einer CSV-Datei

Folgende Situation: In einem Ordner im Dateisystem liegen hunderte Dateien und dutzende dieser Dateien müssen umbenannt werden. Nun hat man nicht unbedingt Lust, jede Datei einzeln anzusprechen und entsprechend umzubenennen…

Was man aber – wenn es gut läuft – hat, ist eine CSV-Datei mit einer Liste dieser Dateien, in der ersten Spalte ist der alte, in der zweiten ist der neue Dateiname -> altneu.csv. Diese Datei kann man nun mit einem Shell-Skript dazu verwenden, alle aufgeführten Dateien umzubenennen -> rename.sh. CSV-Datei und Shell-Skript werden in den Ordner gespielt und das Shell-Skript ausgeführt, fertig!

Wie lautet nun der Inhalt des Shell-Skriptes? So:

#!/bin/bash
while read line
do
   old=$(echo "$line" | awk -F"," '{print $1}')
   new=$(echo "$line" | awk -F"," '{print $2}')
   mv "$old" "$new"
done < altneu.csv

Die CSV-Datei darf natürlich keine Spaltenbezeichnungen enthalten!


Halle/Saale: Meine Bilder vom Laternenfest 2014

Am letzten Wochenende im August findet traditionell das Laternenfest in Halle an der Saale statt, und dieses Jahr waren wir dabei!

[UPDATE]: Die Bilder liegen nun nicht mehr bei Flickr, sondern in meiner eigenen Lychee-Installation:

Burg Giebichenstein


Apache: SSL per .htaccess erzwingen

Wenn man keinen Zugriff auf die Konfigurationsdateien des Apache-Webservers hat, kann man die Benutzung von SSL (https) auch über eine .htaccess-Datei erzwingen. Dazu muß die RewriteEngine natürlich aktiviert sein!

Dies ist der benötigte Eintrag in die htaccess-Datei:

1
2
3
RewriteEngine On
RewriteCond %{SERVER_PORT} 80
RewriteRule ^(.*)$ https://meinedomain.de/$1 [R,L]

Möchte man SSL in einem bestimmten Ordner („meinordner“) erzwingen, so braucht man:

1
2
3
4
RewriteEngine On
RewriteCond %{SERVER_PORT} 80 
RewriteCond %{REQUEST_URI} meinordner 
RewriteRule ^(.*)$ https://meinedomain.de/meinordner/$1 [R,L]

Terminal: Kopieren mehrerer Dateien mit Änderung der Dateiendung

In einigen PHP-Anwendungen bei uns liegen die Konfigurationsdateien im Format „*.php.default“ im entsprechenden Ordner. Wie schafft man es nun am schnellsten, von all diesen Dateien eine Kopie im Format „*.php“ zu erstellen?

Natürlich im Terminal! In den entsprechenden Ordner gehen und dann folgendes aufrufen:

for old in *.default; do cp $old `basename $old .php.default`.php; done

Fertig!


SHA Checksum mit Mac OS X überprüfen

Das „Hashen“ mit SHA wird häufig im Zusammenhang mit dem Verteilen oder Herunterladen von Software benutzt. Dadurch soll die Integrität der heruntergeladenen Dateien sichergestellt werden.
Die Überprüfung kann man auf Mac OS X mit folgendem Befehl im Terminal machen:

shasum /pfad/zur/datei

So wird auf einen SHA1-Hash überprüft. Muß man andere SHA-Hashtypen überprüfen (224, 256, 384, 512), muß man nur den Befehl um den Paramater -a ergänzen. Für SHA256 also:

shasum -a 256 /pfad/zur/datei

Und das war’s dann auch schon.


Endlich! Eine vernünftige Todo-Liste!

Ich bin ja nun schon seit Jahren auf der Suche nach dem perfekten Programm zur Aufgabenverwaltung und habe alles mögliche ausprobiert… Entweder sie waren zu überladen, oder sie waren nicht auf allen Plattformen verfügbar, oder, oder, oder…

Das scheint nun vorbei zu sein! Der Artikel Todo.txt: Geniales To-Do-Listen-Tool für Kommandozeilenliebhaber von t3n hat mich zum Programm Todo.txt gebracht. Perfekt! Auf Mac OS X eingerichtet, auf Arch Linux eingerichtet, Synchronisation über Wuala, alles prima.

Wer näheres zum Programm wissen möchte, den verweise ich auf den t3n-Artikel.


SQL: Lücken in einer Auto-Increment-Spalte finden

Neulich stand ich vor dem Problem, Lücken in einer Auto-Increment-Spalte (in diesem Fall die Spalte id) finden zu müssen. Ich habe diesen Datenbankaufruf dazu gefunden:

1
2
3
4
5
SELECT a.id+1 AS start, MIN(b.id) - 1 AS end
    FROM mytable AS a, mytable AS b
    WHERE a.id < b.id
    GROUP BY a.id
    HAVING start < MIN(b.id);

Und jetzt: Bitmessage!

Für eine – vielleicht – sicherere Kommunikation bin ich ab sofort auch über Bitmessage erreichbar:

BM-2cVLkitXhsBhdGijSoGMirFAiXv7Env4PE

Bitmessage ist cool und macht Spaß… Hier ist der Wikipedia-Artikel.


Alle Prozesse eines Benutzers benden/killen

Falls man mal alle Prozesse eines Benutzers abschießen muß:

kill `ps -u <benutzername> -o "pid="`

Und wenn das alles nichts hilft, weil ein Prozeß hängt, kommt natürlich -9 hinzu:

kill -9 `ps -u <benutzername> -o "pid="`

Dateien mit tar und SSH auf Server übertragen

Dann und wann muß ich große Datenmengen und/oder viele Dateien auf einen Server oder von einem Server auf einen anderen spielen. Das geht am besten mit einem Tarball:

tar cf - . | ssh user@user-server.de "cd folder; tar xf -"

Was macht diese Anweisung? Alles im aktuellen Verzeichnis (.) wird als Tarball gepackt und über ssh auf den Server übertragen. Dort wird in das gewünschte Verzeichnis gewechselt und alles entpackt.