Diskussion:Radiosender: Unterschied zwischen den Versionen

Aus Linupedia.org
Wechseln zu: Navigation, Suche
(Änderung auf linupedia.org Server)
(script für kaffeine importliste)
Zeile 5: Zeile 5:
 
Diese Hilfsscripte sind auf eine stabile Struktur der Wikiseite angewiesen.<br>
 
Diese Hilfsscripte sind auf eine stabile Struktur der Wikiseite angewiesen.<br>
 
Aus diesem Grund sollten Änderungen an dieser Seite mit Vorsicht vorgenommen werden, vor allem
 
Aus diesem Grund sollten Änderungen an dieser Seite mit Vorsicht vorgenommen werden, vor allem
keine 2 Tabelle auf der Seite anlegen.
+
keine 2 Tabelle auf der Seite anlegen. Beachtet bei Änderungen unbedingt die weiter unten gegebenen Hinweise, nur so kann sicher gestellt werden, dass die hier vorgestellten Scripte bei allen Usern auch funktionieren.
  
  
  
 
== Import und Exportfunktionen für die Tabelle ==
 
== Import und Exportfunktionen für die Tabelle ==
 +
 +
=== Daten aus dem Wiki für Tabellenbearbeitung bereitstellen ===
  
 
Für den Export der Daten aus dem Wiki wurde folgendes Script entwickelt.<br>
 
Für den Export der Daten aus dem Wiki wurde folgendes Script entwickelt.<br>
Zeile 55: Zeile 57:
 
-----
 
-----
  
Folgendes Script ist für den umgekehrten Weg gedacht, um geänderte oder neu hinzugekommenen Daten hier in die Tabelle einzutragen.
+
=== Exporthilfe aus Daten-Tabellen für Änderungen im Wiki ===
 +
 
 +
 
 +
Folgendes Script ist für den umgekehrten Weg gedacht, um mit Tabellenbearbeitung geänderte oder neu hinzugekommenen Daten hier in die Tabelle einzutragen.
 
Nach einiger Überlegung wurde darauf verzichtet, das Script so weit auszubauen, dass mit dem Script direkt von eurem Rechner aus die Datenänderungen im
 
Nach einiger Überlegung wurde darauf verzichtet, das Script so weit auszubauen, dass mit dem Script direkt von eurem Rechner aus die Datenänderungen im
 
Wiki vorgenommen werden. Das würde hier Tür und Tor für jeglichen Unfug viel zu weit aufreißen. ;-)
 
Wiki vorgenommen werden. Das würde hier Tür und Tor für jeglichen Unfug viel zu weit aufreißen. ;-)
Zeile 115: Zeile 120:
 
#-----------------END-------------------------------------------------
 
#-----------------END-------------------------------------------------
 
</pre>
 
</pre>
 +
 +
 +
 +
=== Erstellen einer Wiedergabeliste für kaffeine ===
 +
 +
Folgendes Script erzeugt aus den Wikidaten eine Wiedergabeliste die direkt in kaffeine importiert werden kann.
 +
Einfach das Script aufrufen und die Ausgabe in eine Datei zB "'''meine_liste.kaffeine'''" umleiten.
 +
 +
<pre>
 +
#!/bin/bash
 +
#----------------------------------------------------------------------
 +
# Author: robi@linux-club.de
 +
# Version: 2, Last updated: Di 24. Mär 02:14:38 CET 2009
 +
#----------------------------------------------------------------------
 +
# Dieses Script holt über das Internet die Daten der Tabellen auf
 +
# http://www.linupedia.org/opensuse/Radiosender[-1]  und erzeugt eine
 +
# Wiedergabeliste für das Programm kaffeine .
 +
# bei Option -1 oder -2 wird jeweils nur eine Seite ausgelesen,
 +
# default und bei unklaren Optionen werden beide Seiten ausgelesen
 +
#
 +
# Aufruf:                ./script [ -1 | -2 ] > meine_liste.kaffeine
 +
#
 +
#---------------------------------------------------------------------
 +
SEITE1="http://www.linupedia.org/opensuse/Radiosender"
 +
SEITE2="http://www.linupedia.org/opensuse/Radiosender-1"
 +
READ="$SEITE1 $SEITE2"
 +
if [ $# -eq 1 -a  "$1" = "-1" ] ;then READ=$SEITE1;
 +
else if [ $# -eq 1 -a "$1" = "-2" ] ; then READ=$SEITE2; fi
 +
fi
 +
 +
wget -U "" $READ -O - 2>/dev/null | \
 +
  awk '/^<table.*ikitable sortable/,/<\/table/ {print $0}' | \
 +
  awk '/^<tr/,/<\/tr>/ {printf $0} ; /<\/tr>/ {print}'  |\
 +
  sed 's#\(<[^>]*>\)#;#g' | \
 +
  sed -ne 's# *;\{1,\} *#;#gp' | \
 +
  awk -F';' 'BEGIN {OFS=";"}
 +
            NR==1 {print "\"" $2 "\"","\"" $3 "\"","\"" $4 "\"","\"" $5 "\"","\"" $6 "\"","\"" $7 "\""}
 +
            NR!=1 && $2!="Sender" {print "\"" $2 "\"","\"" $3 "\"","\"" $4 "\"",$5,"\"" $6 "\"","\"" ($8 == "" ? $7 : $8)"\""}' |\
 +
  awk -F';' 'BEGIN { print "<!DOCTYPE XMLPlaylist>\n<playlist client=\"kaffeine\" >" }
 +
            NR!=1 && $1!="Sender" {
 +
              TYPE="";
 +
              if (match($6,/.*\.mp3\"$/)) TYPE="audio/x-mp3" ;
 +
              if (match($6,/.*\.wma\"$/)) TYPE="audio/x-ms-wma" ;
 +
              if (match($6,/.*\.wmv\"$/)) TYPE="video/x-ms-wmv" ;
 +
              if (match($6,/.*\.m3u\"$/)) TYPE="audio/mpegurl" ;
 +
              if (match($6,/.*\.ogg\"$/)) TYPE="application/ogg" ;
 +
              if (match($6,/.*\.ra\"$/))  TYPE="audio/vnd.rn-realaudio" ;
 +
              if (match($6,/.*\/\"$/))    TYPE="inode/directory" ;
 +
              if (TYPE=="") TYPE="application/octet-stream" ;
 +
              print " <entry title=" $1, "mime=\"" TYPE "\" url=" $6, "/>"}
 +
            END  {print "</playlist>"} '
 +
#-----------------END-------------------------------------------------
 +
</pre>
 +
 +
 +
  
  
Zeile 121: Zeile 182:
 
* bei Verwendung der obrigen Scripte bitte darauf achten, dass ihr keine "falschen zusätzlichen Zeilenspünge mitkopiert. Das passiert z.B. wenn man die Standardausgabe des 2. Scriptes hier her kopieren würdet. Also die Ausgabe des Scriptes in eine Datei umleiten, diese Datei mit '''cat''' ausgeben und dann diese Konsolausgabe der Datei hier für die Änderungen im Wiki benutzen, dann sollte das Problem nicht auftreten.
 
* bei Verwendung der obrigen Scripte bitte darauf achten, dass ihr keine "falschen zusätzlichen Zeilenspünge mitkopiert. Das passiert z.B. wenn man die Standardausgabe des 2. Scriptes hier her kopieren würdet. Also die Ausgabe des Scriptes in eine Datei umleiten, diese Datei mit '''cat''' ausgeben und dann diese Konsolausgabe der Datei hier für die Änderungen im Wiki benutzen, dann sollte das Problem nicht auftreten.
  
* Bitte nach Änderungen die Vorschau benutzen und bitte genau überprüfen ob die Tabelle und eure neuen Daten auch wirklich ok sind, und wirklich nur dann abspeichern.
+
* Bitte nach Änderungen im Wiki die Vorschau benutzen und bitte genau überprüfen ob die Tabelle und eure neuen Daten auch wirklich ok sind, und wirklich nur dann abspeichern.
  
 
* Eine Datenzeile der Wikitabelle umfasst immer genau 2 zusammengehörende Zeilen beim Editieren der Tabelle:
 
* Eine Datenzeile der Wikitabelle umfasst immer genau 2 zusammengehörende Zeilen beim Editieren der Tabelle:
Zeile 130: Zeile 191:
 
* Sollte ein Sender einmal nicht mehr senden, und keine neue Streamadresse bekannt sein, ist vorgesehen bei der Datenrate eine '''0'''  (Null) einzutragen, und bei der Farbe dazu den Wert "'''#363636'''" . Damit wird die entsprechende Zeile dunkelgrau  und so als z.Z. nicht verfügbar markiert. Erfahrungsgemäß können Sender wegen technischen Problemen über Stunden oder vor allem am Wochenende auch etwas länger offline sein. Bitte die Markierung erst durchführen wenn die Sender über mehrere Tage nicht verfügbar sind.
 
* Sollte ein Sender einmal nicht mehr senden, und keine neue Streamadresse bekannt sein, ist vorgesehen bei der Datenrate eine '''0'''  (Null) einzutragen, und bei der Farbe dazu den Wert "'''#363636'''" . Damit wird die entsprechende Zeile dunkelgrau  und so als z.Z. nicht verfügbar markiert. Erfahrungsgemäß können Sender wegen technischen Problemen über Stunden oder vor allem am Wochenende auch etwas länger offline sein. Bitte die Markierung erst durchführen wenn die Sender über mehrere Tage nicht verfügbar sind.
  
* Vermeidet in der Tabelle '''";"''' das bringt Probleme beim Ex- und Import der Daten mit obrigen Scripten. Achtet darauf, dass bei einer Adresse wie zum Beispiel http://mp3.ht-stream.net/;04026677086949stream.nsv die temporäre Ergänzung der Stream-Adresse weggelassen wird. Das Beispiel ist also einzutragen als http://mp3.ht-stream.net/  
+
* Vermeidet in der Tabelle Sonderzeichen. Es ist bekannt das  '''";"''' in der URL und '''"&"''' und '''"%"''' im Sendernamen Probleme beim Ex- und Import der Daten mit obrigen Scripten bzw bei Import in kaffeine erzeugen.  
 +
 
 +
* Achtet darauf, dass bei einer Adresse wie zum Beispiel http://mp3.ht-stream.net/;04026677086949stream.nsv die temporäre Ergänzung der Stream-Adresse weggelassen wird. Das Beispiel ist also einzutragen als http://mp3.ht-stream.net/  
  
 
* Bitte in die Felder der Tabelle (außer der Adresse natürlich) keine Links oder Webadressen eintragen, sondern nur Text.
 
* Bitte in die Felder der Tabelle (außer der Adresse natürlich) keine Links oder Webadressen eintragen, sondern nur Text.

Version vom 27. März 2009, 21:39 Uhr

Bearbeitungshinweise

Da diese Seite einen hohen Aufwand an ständiger Aktualisierung erfordert entstehen zur Zeit Funktionen für das Importieren und Exportieren der Radiosenderdaten. Diese Hilfsscripte sind auf eine stabile Struktur der Wikiseite angewiesen.
Aus diesem Grund sollten Änderungen an dieser Seite mit Vorsicht vorgenommen werden, vor allem keine 2 Tabelle auf der Seite anlegen. Beachtet bei Änderungen unbedingt die weiter unten gegebenen Hinweise, nur so kann sicher gestellt werden, dass die hier vorgestellten Scripte bei allen Usern auch funktionieren.


Import und Exportfunktionen für die Tabelle

Daten aus dem Wiki für Tabellenbearbeitung bereitstellen

Für den Export der Daten aus dem Wiki wurde folgendes Script entwickelt.
Damit ist es möglich, die Daten der Tabelle für den Import in Tabellenkalkulationsprogramme direkt abzuholen. Da es in der Zwischenzeit zwei Wikiseiten dafür gibt, kann mit einer Option eine einzelne Seite zum Download bestimmt werden. Ohne Option werden immer beide Seiten downgeloadet

#!/bin/bash
#----------------------------------------------------------------------
# Author: robi@linux-club.de
# Version: 3, Last updated: Di 24. Mär 02:14:38 CET 2009
#----------------------------------------------------------------------
# Dieses Script holt über das Internet die Daten der Tabellen auf
# http://www.linupedia.org/opensuse/Radiosender[-1]  und erzeugt eine
# Ausgabe der Daten im csv-Format zum Import in Tabellenverarbeitung
# bei Option -1 oder -2 wird jeweils nur eine Seite ausgelesen,
# default und bei unklaren Optionen werden beide Seiten ausgelesen
#
# Aufruf:                ./script [ -1 | -2 ] > datei.csv
#
# Importeinstellungen:   Zeichensatz:   Unicode (UTF-8)
#                        Ab Zeile   :   1
#                        Feldtrenner:   ;
#                        Texttrenner:   "
#---------------------------------------------------------------------
SEITE1="http://www.linupedia.org/opensuse/Radiosender"
SEITE2="http://www.linupedia.org/opensuse/Radiosender-1"
READ="$SEITE1 $SEITE2"
if [ $# -eq 1 -a  "$1" = "-1" ] ;then READ=$SEITE1;
 else if [ $# -eq 1 -a "$1" = "-2" ] ; then READ=$SEITE2; fi
fi
wget -U "" $READ -O - 2>/dev/null | \
  awk '/^<table.*ikitable sortable/,/<\/table/ {print $0}' | \
  awk '/^<tr/,/<\/tr>/ {printf $0} ; /<\/tr>/ {print}'  |\
  sed 's#\(<[^>]*>\)#;#g' | \
  sed -ne 's# *;\{1,\} *#;#gp' | \
  awk -F';' 'BEGIN {OFS=";"}
             NR==1 {print "\"" $2 "\"","\"" $3 "\"","\"" $4 "\"","\"" $5 "\"","\"" $6 "\"","\"" $7 "\""}
             NR!=1 && $2!="Sender" {print "\"" $2 "\"","\"" $3 "\"","\"" $4 "\"",$5,"\"" $6 "\"","\"" ($8 == "" ? $7 : $8)"\""}'

#-----------------END-------------------------------------------------



Exporthilfe aus Daten-Tabellen für Änderungen im Wiki

Folgendes Script ist für den umgekehrten Weg gedacht, um mit Tabellenbearbeitung geänderte oder neu hinzugekommenen Daten hier in die Tabelle einzutragen. Nach einiger Überlegung wurde darauf verzichtet, das Script so weit auszubauen, dass mit dem Script direkt von eurem Rechner aus die Datenänderungen im Wiki vorgenommen werden. Das würde hier Tür und Tor für jeglichen Unfug viel zu weit aufreißen. ;-)

Es bleibt euch also letztlich doch noch die Daten hier im Wiki auf die alt hergebrachte Weise zu editieren und zu erweitern. Allerdings hilft euch das Script dabei.
Es ist so konzipiert, das es das Datenformat, das das erste Script anlegt, und welches ihr mit Tabellenkalkulation oder Datenbank bearbeiten könnt und von dort aus auch genau so wieder abspeichern könnt, in genau das Format umwandelt, das hier im Wiki im Bearbeitungsfenster eingegeben werden muss.

Es wird mit dem Script jeweils eine komplette Tabelle erzeugt. Ihr könnt daraus die jeweiligen Bereiche hier einfach hineinkopieren, bzw. ( aber bitte nur nach wirklich größeren Änderungen ) die gesamte Tabelle durch die neuen Daten austauschen, indem ihr im Editorfenster die alte Tabellendaten komplett löscht, und dafür die Ausgabe des Scriptes wieder hineinkopiert. Eine Aufteilung der Daten auf die beiden Wikiseiten ist derzeit noch nicht implemeniert, das muss vorläufig noch per Hand entschieden werden. Auf einer Seite sind maximal ca. 400 Tabelleneinträge mögliche, danach kommt eine Fehlermeldung bei Versuch die Wikiseite zu speichern. Einige Anmerkungen und Hinweise dazu folgen noch, hier erstmal das Script.


#!/bin/bash
#----------------------------------------------------------------------
# Author: robi@linux-club.de
# Version: 3, Last updated: Di 24. Mär 02:14:38 CET 2009
#----------------------------------------------------------------------
# Dieses Script konvertiert eine CSV-Datei in das passende Wiki-Format
# als Hilfe zum Einfügen und Ändern der Daten auf
# http://www.linupedia.org/opensuse/Radiosender
# erzeugt wird die komplette Tabelle aus den übergebenen Daten
#
# Aufruf:                ./script datei.csv > wiki-tabelle.dat
#
# Exporteinstellungen:   Zeichensatz:   Unicode (UTF-8)
#                        Ab Zeile   :   1
#                        Feldtrenner:   ;
#                        Texttrenner:   "
#---------------------------------------------------------------------

if [ $# != 1 ]; then echo -e "\nAufruf: $0 datei.csv \n\n";exit 1;fi
if [ -r "$1" -a -f "$1" ]; then
if [ "$(head -1 "$1" |cut -d';' -f5 |cut -d'"' -f2)" != "Hinweis" ]; then
  echo -e "\n\"$1\" scheint keine für dieses Script geeignete CSV-Datei zu sein\n\n";exit 2;fi
else echo -e "\n\"$1\" ist keine lesbare Datei\n\n"; exit 3;fi

awk -F';' '{ split($1,NAME,"\"");
             split($2,STADT,"\"");
             split($3,LAND,"\"");
             split($4,BIT,"\"");
             split($5,BEMERK,"\"");
             split($6,ADDR,"\"") }

     NR==1 { print "{| class=\"wikitable sortable\" border=\"1\" cellspacing=\"0\""
             print " |- style=\"background-color:#009ACD;\""
             printf " !" NAME[2] "!!" STADT[2] "!!" LAND[2] "!!" BIT[2] "!!"
             print " class=\"unsortable\"| " BEMERK[2] "!!class=\"unsortable\"|" ADDR[2] }

     NR!=1 { FARBE= "#FFCC00" ;
             if (BIT[1] < 63  )  FARBE= "#FFFF00" ;
             if (BIT[1] == 0  )  FARBE= "#363636" ;
             if (BIT[1] > 93  )  FARBE= "#FF9900" ;
             if (BIT[1] > 128 )  FARBE= "#FF6600" ;
             print  "|- style=\"background-color:" FARBE ";\""
             print "|",NAME[2],"||",STADT[2],"||",LAND[2],"||align=\"center\" |",BIT[1],"||",BEMERK[2],"||",ADDR[2]  }

       END { print "|}"      }' "$1"

#-----------------END-------------------------------------------------


Erstellen einer Wiedergabeliste für kaffeine

Folgendes Script erzeugt aus den Wikidaten eine Wiedergabeliste die direkt in kaffeine importiert werden kann. Einfach das Script aufrufen und die Ausgabe in eine Datei zB "meine_liste.kaffeine" umleiten.

#!/bin/bash
#----------------------------------------------------------------------
# Author: robi@linux-club.de
# Version: 2, Last updated: Di 24. Mär 02:14:38 CET 2009
#----------------------------------------------------------------------
# Dieses Script holt über das Internet die Daten der Tabellen auf
# http://www.linupedia.org/opensuse/Radiosender[-1]  und erzeugt eine
# Wiedergabeliste für das Programm kaffeine .
# bei Option -1 oder -2 wird jeweils nur eine Seite ausgelesen,
# default und bei unklaren Optionen werden beide Seiten ausgelesen
#
# Aufruf:                ./script [ -1 | -2 ] > meine_liste.kaffeine
#
#---------------------------------------------------------------------
SEITE1="http://www.linupedia.org/opensuse/Radiosender"
SEITE2="http://www.linupedia.org/opensuse/Radiosender-1"
READ="$SEITE1 $SEITE2"
if [ $# -eq 1 -a  "$1" = "-1" ] ;then READ=$SEITE1;
else if [ $# -eq 1 -a "$1" = "-2" ] ; then READ=$SEITE2; fi
fi

wget -U "" $READ -O - 2>/dev/null | \
  awk '/^<table.*ikitable sortable/,/<\/table/ {print $0}' | \
  awk '/^<tr/,/<\/tr>/ {printf $0} ; /<\/tr>/ {print}'  |\
  sed 's#\(<[^>]*>\)#;#g' | \
  sed -ne 's# *;\{1,\} *#;#gp' | \
  awk -F';' 'BEGIN {OFS=";"}
             NR==1 {print "\"" $2 "\"","\"" $3 "\"","\"" $4 "\"","\"" $5 "\"","\"" $6 "\"","\"" $7 "\""}
             NR!=1 && $2!="Sender" {print "\"" $2 "\"","\"" $3 "\"","\"" $4 "\"",$5,"\"" $6 "\"","\"" ($8 == "" ? $7 : $8)"\""}' |\
  awk -F';' 'BEGIN { print "<!DOCTYPE XMLPlaylist>\n<playlist client=\"kaffeine\" >" }
             NR!=1 && $1!="Sender" {
               TYPE="";
               if (match($6,/.*\.mp3\"$/)) TYPE="audio/x-mp3" ;
               if (match($6,/.*\.wma\"$/)) TYPE="audio/x-ms-wma" ;
               if (match($6,/.*\.wmv\"$/)) TYPE="video/x-ms-wmv" ;
               if (match($6,/.*\.m3u\"$/)) TYPE="audio/mpegurl" ;
               if (match($6,/.*\.ogg\"$/)) TYPE="application/ogg" ;
               if (match($6,/.*\.ra\"$/))  TYPE="audio/vnd.rn-realaudio" ;
               if (match($6,/.*\/\"$/))    TYPE="inode/directory" ;
               if (TYPE=="") TYPE="application/octet-stream" ;
               print " <entry title=" $1, "mime=\"" TYPE "\" url=" $6, "/>"}
             END  {print "</playlist>"} '
#-----------------END-------------------------------------------------



Hinweise für das Ändern der Datentabelle

  • bei Verwendung der obrigen Scripte bitte darauf achten, dass ihr keine "falschen zusätzlichen Zeilenspünge mitkopiert. Das passiert z.B. wenn man die Standardausgabe des 2. Scriptes hier her kopieren würdet. Also die Ausgabe des Scriptes in eine Datei umleiten, diese Datei mit cat ausgeben und dann diese Konsolausgabe der Datei hier für die Änderungen im Wiki benutzen, dann sollte das Problem nicht auftreten.
  • Bitte nach Änderungen im Wiki die Vorschau benutzen und bitte genau überprüfen ob die Tabelle und eure neuen Daten auch wirklich ok sind, und wirklich nur dann abspeichern.
  • Eine Datenzeile der Wikitabelle umfasst immer genau 2 zusammengehörende Zeilen beim Editieren der Tabelle:
|- style="background-color:#FFFF00;"
| Bayern 1 || München || Deutschland ||align="center" | 48 || - || mms://gffstream-w1b.wm.llnwd.net/gffstream_w1b
In der ersten Zeile wird die Hintergrundfarbe gesetzt, das macht das obrige Script automatisch, in der 2. Zeile stehen dann die Daten.
  • Sollte ein Sender einmal nicht mehr senden, und keine neue Streamadresse bekannt sein, ist vorgesehen bei der Datenrate eine 0 (Null) einzutragen, und bei der Farbe dazu den Wert "#363636" . Damit wird die entsprechende Zeile dunkelgrau und so als z.Z. nicht verfügbar markiert. Erfahrungsgemäß können Sender wegen technischen Problemen über Stunden oder vor allem am Wochenende auch etwas länger offline sein. Bitte die Markierung erst durchführen wenn die Sender über mehrere Tage nicht verfügbar sind.
  • Vermeidet in der Tabelle Sonderzeichen. Es ist bekannt das ";" in der URL und "&" und "%" im Sendernamen Probleme beim Ex- und Import der Daten mit obrigen Scripten bzw bei Import in kaffeine erzeugen.
  • Bitte in die Felder der Tabelle (außer der Adresse natürlich) keine Links oder Webadressen eintragen, sondern nur Text.
  • Haltet euch an das Tabellenformat, sollten Änderungen am Format notwendig werden, dann können wird darüber gerne diskutieren, und dann können gegebenenfalls auch parallel dazu dann die Scripte an das neue Format angepasst werden.
  • Fällt euch auf, das einzelnen Sender nicht mehr senden und ihr euch nicht an die Tabelle traut, dann könnt ihr das auch gerne hier im Anschluss auf der Diskussionseite melden, damit der Nächste das prüfen und gegebenenfalls dann abändern kann.
  • Sollte es dennoch Editierunfälle, Probleme, Unklarheiten, Verständnissprobleme oder sonstige irgendwie gearteter Probleme mit dieser Wikiseite geben, bitte im Wikiforum melden, da wird man euch schnellstmöglich helfen.
  • Denkt daran: einige haben in diese Seite eine ganze Menge Zeit investiert, und davon sollen auch morgen noch möglichst viele Wikileser ihren Nutzen ziehen können.


Dann allseits guten Radioempfang Robi 22:01, 5. Dez. 2008 (UTC)