Kategorien
FreewarWiki:Bot/Skripts/Waffenliste.php: Unterschied zwischen den Versionen
< FreewarWiki:Bot | Skripts
K (Script Update, mit der Version ist der Artikel entstanden) |
Bwoebi (Diskussion | Beiträge) (* Draco für das Mixen von Whitespaces und Tabs haut * Generalisiert für Angriffs- und Verteidigungswaffen) |
||
Zeile 3: | Zeile 3: | ||
<pre> | <pre> | ||
<?php | <?php | ||
$cats = array("Verteidigungswaffen", "Angriffswaffen"); | |||
if (!isset($argv[1]) && !in_array($argv[1], $cats)) { | |||
die("Nutzung: php Waffenliste.php arg\narg ist dabei einer der folgenden Werte: " . implode(", ", $cats) . "\n"); | |||
} | |||
//Benutzername wird für den User-Agent benötigt | //Benutzername wird für den User-Agent benötigt | ||
$bot = new mwBot('Beispieluser', 'www.fwwiki.de'); | $bot = new mwBot('Beispieluser', 'www.fwwiki.de'); | ||
//HINWEIS: Skript schreibt Output in die Textdatei output.txt, evtl muss diese bestehen und die nötigen Rechte gegeben sein! | //HINWEIS: Skript schreibt Output in die Textdatei output.txt, evtl muss diese bestehen und die nötigen Rechte gegeben sein! | ||
if (false === $bot->print2file($bot->start())) { | if (false === $bot->print2file($bot->start($argv[1]))) { | ||
echo 'Daten konnten nicht geschrieben werden, Datei "output.txt" vorhanden und beschreibbar?'; | |||
} | } | ||
Zeile 21: | Zeile 26: | ||
public function status($status, $code = 0) { | public function status($status, $code = 0) { | ||
print date("d.m.y H:i:s") . " => " . $status . ($code == 0?"":(" (".$code.")")) . " | print date("d.m.y H:i:s") . " => " . $status . ($code == 0?"":(" (".$code.")")) . "\n"; | ||
} | } | ||
Zeile 55: | Zeile 60: | ||
#################################*/ | #################################*/ | ||
/* Main-Funktion - sucht die | /* Main-Funktion - sucht die Artikel einer Waffenkategorie und baut die Wiki-Seite auf */ | ||
public function start() { | public function start($cat) { | ||
$pages = $this->getAPI('action=query&list=categorymembers&cmtitle=Category:' . urlencode( | $pages = $this->getAPI('action=query&list=categorymembers&cmtitle=Category:' . urlencode($cat) . '&cmlimit=500'); | ||
foreach($pages['categorymembers'] as $page) { | foreach($pages['categorymembers'] as $page) { | ||
Zeile 75: | Zeile 80: | ||
// Aufbau der Liste | // Aufbau der Liste | ||
$out = | $out = "<noinclude></noinclude><!--Diese Liste wird von Zeit zu Zeit automatisch aus den Daten aus den einzelnen $cat-Artikeln erstellt (zuletzt am '''" . date("d.m.Y H:i:s") . "'''). Das Script um die Liste zu akualisieren findet ihr hier //TODO: Scriptlink einfuegen // "; | ||
$out .= "\n\n"; | $out .= "\n\n"; | ||
$out .= "Anzahl Waffen: " . $count . "\n\n"; | $out .= "Anzahl Waffen: " . $count . "\n-->{{#vardefine:" . $cat . "Anzahl|" . $count . "}}<!--\n\n"; | ||
// Durchlaufen des Waffen-Arrays und Hinzufuegen zur Liste | // Durchlaufen des Waffen-Arrays und Hinzufuegen zur Liste | ||
foreach($waffenArray as $currentWaffe) { | foreach($waffenArray as $currentWaffe) { | ||
$out .= "\n-->{{ {{{Vorlage}}} | Name=" . ($currentWaffe -> name) . "}}<!--" ; | $out .= "\n-->{{{{{Vorlage}}}|Name=" . ($currentWaffe->name) . "}}<!--" ; | ||
} | } | ||
return $out . "\n-->"; | return $out . "\n-->"; | ||
Zeile 89: | Zeile 94: | ||
private function isWaffe($content) { | private function isWaffe($content) { | ||
// Ueberpruefung ob der Artikel dem Layout fuer eine Angriffswaffe entspricht | // Ueberpruefung ob der Artikel dem Layout fuer eine Angriffswaffe entspricht | ||
if ( preg_match(' | if ( preg_match('~Item/Layout|Typ=awaffe~', $content) ) { | ||
// Ueberpruefung ob der Artikel eine saisonale Waffe beschreibt | // Ueberpruefung ob der Artikel eine saisonale Waffe beschreibt | ||
if ( !(preg_match('/Saisonale Items/', $content)) ) { | if ( !(preg_match('/Saisonale Items/', $content)) ) { | ||
Zeile 101: | Zeile 106: | ||
private function createWaffe($content, $name) { | private function createWaffe($content, $name) { | ||
preg_match('#Stärke=\W*([0-9]+)#si', $content, $staerke); | preg_match('#Stärke=\W*([0-9]+)#si', $content, $staerke); | ||
return new Waffe( $name, ($staerke[1]) ); | |||
} | } | ||
public function print2file($str, $file = 'output.txt') { | public function print2file($str, $file = 'output.txt') { | ||
Zeile 111: | Zeile 114: | ||
} | } | ||
class Waffe { | class Waffe { | ||
public $name; | public $name; | ||
public $staerke; | public $staerke; | ||
// Konstruktor fuer ein Waffen-Objekt | // Konstruktor fuer ein Waffen-Objekt | ||
function | function __construct($name, $staerke){ | ||
$this->name = $name; | |||
$this->staerke = $staerke; | $this->staerke = $staerke; | ||
} | |||
// Vergleichsfunktion fuer Waffen-Objekte | // Vergleichsfunktion fuer Waffen-Objekte | ||
static function cmpWaffe($waffe1, $waffe2){ | static function cmpWaffe($waffe1, $waffe2){ | ||
$staerke1 = $waffe1->staerke; | |||
$staerke2 = $waffe2->staerke; | |||
if ($staerke1 == $staerke2) { | |||
return strcasecmp($waffe1->name, $waffe2->name); | |||
} | |||
return $staerke1 - $staerke2; | |||
} | |||
} | } | ||
</pre> | </pre> |
Version vom 14. Januar 2015, 01:54 Uhr
<?php $cats = array("Verteidigungswaffen", "Angriffswaffen"); if (!isset($argv[1]) && !in_array($argv[1], $cats)) { die("Nutzung: php Waffenliste.php arg\narg ist dabei einer der folgenden Werte: " . implode(", ", $cats) . "\n"); } //Benutzername wird für den User-Agent benötigt $bot = new mwBot('Beispieluser', 'www.fwwiki.de'); //HINWEIS: Skript schreibt Output in die Textdatei output.txt, evtl muss diese bestehen und die nötigen Rechte gegeben sein! if (false === $bot->print2file($bot->start($argv[1]))) { echo 'Daten konnten nicht geschrieben werden, Datei "output.txt" vorhanden und beschreibbar?'; } class mwBot { private $server; private $nick; public function __construct($name, $server) { $this->nick = $name; $this->server = $server; } public function status($status, $code = 0) { print date("d.m.y H:i:s") . " => " . $status . ($code == 0?"":(" (".$code.")")) . "\n"; } /*################################# # APIVERBINDUNG ## #################################*/ private function getAPI($query) { $c = curl_init('http://' . $this->server . '/api.php?' . $query . '&format=json'); curl_setopt($c, CURLOPT_USERAGENT, 'BotFrameWorkApi -- Benutzer:' . $this->nick); curl_setopt($c, CURLOPT_RETURNTRANSFER, true); $result = curl_exec($c); curl_close($c); $decoded = json_decode($result, true); return $decoded['query']; } /*################################# # HILFSFUNKTIONEN ## #################################*/ private function getContent($title) { $this->status('Hole Artikel: ' . htmlentities($title)); $result = $this->getAPI('action=query&prop=info|revisions&titles=' . urlencode($title) . '&rvprop=timestamp|content&intoken=edit'); $pages = $result['pages']; foreach($pages as $page) { return $page['revisions'][0]['*']; } } /*################################# # SPEZIELLE FUNKTIONEN ## #################################*/ /* Main-Funktion - sucht die Artikel einer Waffenkategorie und baut die Wiki-Seite auf */ public function start($cat) { $pages = $this->getAPI('action=query&list=categorymembers&cmtitle=Category:' . urlencode($cat) . '&cmlimit=500'); foreach($pages['categorymembers'] as $page) { $content = $this->getContent($page['title']); if ($this->isWaffe($content)) { $waffenArray[] = $this->createWaffe($content, ($page['title'])); } else { echo "Artikel beschreibt keine Waffe!"; } } // Sortierung des Arrays nach der Staerke der Waffen-Objekte usort($waffenArray, array("Waffe", "cmpWaffe")); // Zaehlen der Waffen $count = count($waffenArray); // Aufbau der Liste $out = "<noinclude></noinclude><!--Diese Liste wird von Zeit zu Zeit automatisch aus den Daten aus den einzelnen $cat-Artikeln erstellt (zuletzt am '''" . date("d.m.Y H:i:s") . "'''). Das Script um die Liste zu akualisieren findet ihr hier //TODO: Scriptlink einfuegen // "; $out .= "\n\n"; $out .= "Anzahl Waffen: " . $count . "\n-->{{#vardefine:" . $cat . "Anzahl|" . $count . "}}<!--\n\n"; // Durchlaufen des Waffen-Arrays und Hinzufuegen zur Liste foreach($waffenArray as $currentWaffe) { $out .= "\n-->{{{{{Vorlage}}}|Name=" . ($currentWaffe->name) . "}}<!--" ; } return $out . "\n-->"; } /* Ueberpruefung ob der Artikel eine Waffe ist */ private function isWaffe($content) { // Ueberpruefung ob der Artikel dem Layout fuer eine Angriffswaffe entspricht if ( preg_match('~Item/Layout|Typ=awaffe~', $content) ) { // Ueberpruefung ob der Artikel eine saisonale Waffe beschreibt if ( !(preg_match('/Saisonale Items/', $content)) ) { return true; } } return false; } /* Erstellen eines neuen Waffen-Objektes */ private function createWaffe($content, $name) { preg_match('#Stärke=\W*([0-9]+)#si', $content, $staerke); return new Waffe( $name, ($staerke[1]) ); } public function print2file($str, $file = 'output.txt') { return file_put_contents($file, $str); } } class Waffe { public $name; public $staerke; // Konstruktor fuer ein Waffen-Objekt function __construct($name, $staerke){ $this->name = $name; $this->staerke = $staerke; } // Vergleichsfunktion fuer Waffen-Objekte static function cmpWaffe($waffe1, $waffe2){ $staerke1 = $waffe1->staerke; $staerke2 = $waffe2->staerke; if ($staerke1 == $staerke2) { return strcasecmp($waffe1->name, $waffe2->name); } return $staerke1 - $staerke2; } }