FreewarWiki:Bot/Skripts/Waffenliste.php: Unterschied zwischen den Versionen

aus FreewarWiki, der Referenz für Freewar
Zur Navigation springen Zur Suche springen
K (Script Update, mit der Version ist der Artikel entstanden)
(* 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?';
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.")")) . "<br/>";
print date("d.m.y H:i:s") . " => " . $status . ($code == 0?"":(" (".$code.")")) . "\n";
}
}
Zeile 55: Zeile 60:
#################################*/
#################################*/
/* Main-Funktion - sucht die Angriffswaffen-Artikel und baut die Wiki-Seite auf */
/* 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('Angriffswaffen') . '&cmlimit=500');
$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 = htmlentities("<noinclude></noinclude><!--Diese Liste wird von Zeit zu Zeit automatisch aus den Daten aus den einzelnen Angriffswaffen-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 = "<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('/Item\/Layout|Typ=awaffe/', $content) ) {
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);
$newWaffe = new Waffe( $name, ($staerke[1]) );
return new Waffe( $name, ($staerke[1]) );
return $newWaffe;
}
}
public function print2file($str, $file = 'output.txt') {
public function print2file($str, $file = 'output.txt') {
Zeile 111: Zeile 114:
}
}


/* Waffen-Objekt */
class Waffe {
class Waffe {
public $name;
public $name;
public $staerke;
public $staerke;
// Konstruktor fuer ein Waffen-Objekt
// Konstruktor fuer ein Waffen-Objekt
function Waffe ($name, $staerke){
function __construct($name, $staerke){
        $this->name    = $name;
$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;
$staerke1 = $waffe1->staerke;
        $staerke2 = $waffe2 -> staerke;
$staerke2 = $waffe2->staerke;
        if ($staerke1 == $staerke2) {
if ($staerke1 == $staerke2) {
$name1 = $waffe1 -> name;
return strcasecmp($waffe1->name, $waffe2->name);
$name2 = $waffe2 -> name;
}
return ($name1 > $name2) ? +1 : -1;
return $staerke1 - $staerke2;
        }
}
        return ($staerke1 > $staerke2) ? +1 : -1;
    }
}
}


</pre>
</pre>

Version vom 14. Januar 2015, 01:54 Uhr

Dieses Script ist hier lediglich archiviert und nicht direkt lauffähig. Wenn Du es benutzen möchtest, musst Du es lokal abspeichern und mit einem geeigneten Interpreter ausführen lassen. Zum Übernehmen solltest Du nicht den unten angezeigten Text verwenden, sondern den Quelltext des Wiki-Artikels: Dazu wählst Du Bearbeiten und kopierst den (meist zwischen PRE-Tags eingefassten) Scripttext.

Sofern Du die Scripte dauerhaft lokal abgespeichert hältst, solltest Du sie vor der nächsten Ausführung darauf prüfen, ob sie noch aktuell sind.

Letzter Bearbeiter: Bwoebi — Zuletzt bearbeitet: 14.01.2015
<?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;
	}
}