Da ich inzwischen automatisiert eine CSV-Datei aller Netzwerkdrucker erzeuge, bleibt noch die Anzeige dieser Liste. Der erste Schritt dies in Excel zu realisieren liegt zwar nahe, ist aber eher … suboptimal.
Da ich eh einen Apache-Server am laufen habe, soll dieser genutzt werden. In diesem Beitrag gehe ich aber von einem lokalen XAMPP aus.
Warum XAMPP?
Weil ich mich mit IIS nicht auskenne und der XAMPP auch als Portable-Version ausgeführt werden kann. Reicht auch für eine kleine Intranetseite.
Dass es aber noch einfacher geht, erkannte ich erst später. Dazu aber mehr in diesem Beitrag.
Wie man die Liste auf einem dedizierten Webserver zu Verfügung stellen kann, zeige ich hier.
Aber zurück zum eigentlichen Problem: Das Anzeigen einer CSV-Datei als HTML-Tabelle.
Dazu erzeuge ich die Datei „index.php“ im Webserver-/Xampp-Verzeichnis und nutze ein PHP-Skript:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
<table border=1 cellspacing=0 cellpadding=3> <tr><th>Druckername</th><th>Druckerport</th><th>Freigabename</th><th>Ort</th><th>Servername</th></tr> <?php $filename = 'C:\___skript\komplett.csv'; $f = fopen($filename, "r"); while (($line = fgetcsv($f)) !== false) { echo "<tr>"; foreach ($line as $cell) { echo "<td>" . htmlspecialchars($cell) . "</td>"; } echo "</tr>\n"; } fclose($f); ?> </table> |
Das wars auch schon.
Möchte man jetzt noch anzeigen, welchen Stand die Liste hat, kann man noch den Zeitstempel der Datei auslesen und ausgeben.
Um Fehler zu vermeiden, mach ich das mit einer Prüfung ob die Datei auch wirklich existiert.
1 2 3 4 5 6 |
<?php if (file_exists($filename)) { echo "Liste wurde zuletzt aktualisiert am " . date ("d.m.Y ", filemtime($filename)) . " um " . date ("H:i.", filemtime($filename)); // echo "<br><br>"; } ?> |
Mit einer kleinen Überschrift könnte das fertige PHP-Skript so aussehen:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
<html> <body> <h1>Druckerübersicht</h1> <?php $filename = 'C:\___skript\komplett.csv'; if (file_exists($filename)) { echo "Liste wurde zuletzt aktualisiert am " . date ("d.m.Y ", filemtime($filename)) . " um " . date ("H:i.", filemtime($filename)); // echo "<br><br>"; } ?> <!-- ######################################## Erzeugen der HTML-Tabelle aus CSV-Datei ######################################## --> <table border=1 cellspacing=0 cellpadding=3> <tr><th>Druckername</th><th>Druckerport</th><th>Freigabename</th><th>Ort</th><th>Servername</th></tr> <?php $f = fopen($filename, "r"); while (($line = fgetcsv($f)) !== false) { echo "<tr>"; foreach ($line as $cell) { echo "<td>" . htmlspecialchars($cell) . "</td>"; } echo "</tr>\n"; } fclose($f); ?> </table> </body> </html> |
Schon mal ein Anfang.
Die Drucker werden aufgelistet und man kann über die Browser-Suche die Liste durchsuchen.
Eigentlich das, was ich wollte: Einfach, Übersichtlich, Hilfreich.
Aber ein bisschen mehr darfs dann doch sein – z.B.: eine Suchfunktion.
Pimp meine Liste – im Teil 5