Extension:Replace Text/cs

Replace Text (nahradit text) je rozšíření MediaWiki, které poskytuje speciální stránku, stejně jako skript příkazového řádku, umožňující administrátorům provádět globální hledání a nahrazování řetězce na straně serveru v textu i názvech obsahových stránek wiki.

Operace nahrazení textu je odložená operace a je zařazena do fronty úloh. Můžete spustit  ze složky   a okamžitě provést změnu a zpracovat frontu úloh.

Použití
Replace text definuje speciální stránku na "Special:ReplaceText" (nebo její ekvivalent v jiném jazyce), která zpracovává globální vyhledávání a nahrazování. Také definuje skript replaceAll.php, který dělá totéž z příkazového řádku. Tato dokumentace nejprve pokryje speciální stránku a poté skript příkazového řádku.

Na stránce Special:ReplaceText se nejdříve zobrazí formulář pro administrátora, aby vyplnil podrobnosti o hledání a nahrazení: Administrátor zadá hledaný řetězec a jeho nahrazení, sadu jmenných prostorů, ve kterých se má hledat, a také volbu, zda má být textem na stránce nahrazen obsah, názvy stránek nebo obojí. Volitelně může správce také přidat dva další filtry: Název kategorie, do které musí patřit všechny stránky, a předponu, kterou musí všechny názvy stránek začínat. Když je tento formulář odeslán, zobrazí se seznam buď všech stránek, které obsahují daný hledaný řetězec, nebo všech stránek, jejichž názvy obsahují hledaný řetězec, nebo obojí. Vedle názvu každé stránky je zaškrtávací políčko pro každou stránku, takže lze zrušit výběr stránek, které uživatel nahradit nechce. Uživatel pak může kliknout na "Replace" a provést skutečnou změnu. Jakmile je nahrazení textu provedeno, nelze jej přímo vrátit zpět. I když vždy můžete spustit "reverzní" nahrazení, nahrazující nový řetězec původním řetězcem. Z tohoto důvodu, pokud je náhradní řetězec prázdný nebo se jedná o řetězec, který již na wiki existuje, se zobrazí uživateli varovná zpráva.

Pokud je hledaný řetězec na stránce obsažen vícekrát, bude nahrazen každý takový výskyt. Nahrazení každé stránky se zobrazí jako (malá) úprava wiki, přičemž správce, který provedl nahrazení textu, je uživatel, který provedl úpravu, a shrnutí úprav, které se zobrazí jako "Text replace: ' search string ' to ' replacement string '" (nahrazení textu: 'hledaný řetězec' na 'náhradní řetězec').

Název stránky nelze přesunout do názvu, který již na wiki existuje, nebo do titulku, který má více řádků. Stránky, které nelze přesunout, budou jednoduše uvedeny na stránce "select" (vybrat) jako nepřemístitelné, bez zaškrtávacího políčka vedle nich.

Vyhledávání rozlišuje malá a velká písmena. Viz níže, jak nastavit, aby se nerozlišovala malá a velká písmena.



Důležité poznámky

 * 1) ReplaceText ve výchozím nastavení zpracovává pouze 250 stránek najednou. Chcete-li to změnit, můžete v LocalSettings.php nastavit   na vyšší hodnotu. Můžete však být omezeni   PHP. Pokud rozšíření hlásí takové varování, možná ho budete muset změnit.
 * 2) Všechny náhrady jsou umístěny do fronty úloh. Pokud tedy musíte zpracovat velké množství stránek, budete muset spustit Replace Text a poté spustit " " (potenciálně vícekrát).



Použití regulárních výrazů
Pokud používáte databázi MySQL nebo PostgreSQL, uvidíte ve formuláři Special:ReplaceText zaškrtávací políčko "Use regular expressions" (použít regulární výrazy). Toto zaškrtávací políčko se nezobrazuje u databází SQLite, protože SQLite postrádá nativní operátor "REGEXP".

Pokud kliknete na toto zaškrtávací políčko, můžete v rámci vyhledávacích a nahrazovacích řetězců použít regular expressions neboli regulární výrazy. Sada povolených regulárních výrazů je v podstatě malá podmnožina sady regulárních výrazů PHP a MySQL/PostgreSQL. Speciální znaky, které lze použít ve vyhledávacím řetězci, jsou " . * + ? [ ] |" a v rámci náhradního řetězce lze použít hodnoty jako $1, $2 atd. (Chcete-li je použít jako běžné znaky, stačí je nejprve opustit přidáním "\" – což byste také museli udělat se znakem "/".) Tato část nebude poskytovat návod na používání regulárních výrazů (článek na Wikipedii je dobrým místem, kde začít, stejně jako tato stránka na MySQL regexps), ale zde je základní příklad uvedený v inline vysvětlení:


 * Vyhledávací řetězec -
 * Náhradní řetězec -

This would look for pages containing the letter 'a', the letter 'c', and any text in between (signified by the ".*"). It would then put that middle text after the 'a' and 'c' - the "$1" in the replacement string refers to the first element of the search string contained within parentheses (in this case, there's only one).

Pro každou stránku, pro kterou je nahrazení skutečně voláno, by nahrazení nastalo pro každý výskyt hledaného řetězce, nejen pro jeden – stejně jako se to děje u běžného vyhledávání s neregulárními výrazy.



Složitější regulární výrazy

 * Vyhledávací řetězec -
 * Náhradní řetězec -

To by nahradilo "hello222.555" slovy "222,555" a "hello2.55" with "2,55"

Nejprve se shoduje slovo "hello". V závorkách následuje výraz pro hledání libovolných číslic "0-9". Následující hvězdička najde více shod předchozího prvku. Závorky a hvězdička jsou uzavřeny v závorkách, shodujeme se s úplným výrazem a převedeme jej na $1. "\." znamená, že se jedná o skutečnou tečku, nikoli o speciální znak. Druhý výraz v závorkách je porovnán a vložen do $2.



Náhrady následované čísly
Následující nebude fungovat:


 * Vyhledávací řetězec -
 * Náhradní řetězec -

That's because the search will think the number of the replacement is 1123456, not 1. Místo toho byste měli mít následující:


 * Náhradní řetězec -

Obecně platí, že očíslované hodnoty můžete vždy uzavřít do složených závorek.



Vyhledávání bez rozlišení malých a velkých písmen
To make your search case-insensitive, use regular expression and the case-insensitive modifier, :
 * Vyhledávací řetězec -
 * Náhradní řetězec -

Výše uvedené sjednotí obal všech zmínek o iPhone/iphone/IPHONE na iPhone.



Skript příkazového řádku: replaceAll.php
Replace Text offers a script, replaceAll.php, in the  directory, which can be run from the command line, and which does all the same replacements that the page Special:ReplaceText does. První dva argumenty pro tento skript by měly být hledaný text a nahrazující text. Tento můžete skript nazvat jednoduše takto:

php replaceAll.php "Leningrad" "St. Petersburg"

If you use numbered values like $1 in the replacement string, you have to either escape them inside double quotes like  or use single quotes. Jinak shell na jejich místo umístí mezery, protože si myslí, že jde o proměnné.

Další možné argumenty/příznaky pro tento skript jsou:

Additionally, there are two flags that strictly print out helpful information unrelated to a specific text replacement:

(Všechny tyto možnosti můžete zobrazit také voláním "php replaceAll.php --help".)



Přiřazení náhrad uživateli
Ve výchozím nastavení jsou všechna nahrazení připsána v historii stránek uživateli, který je inicioval. Místo toho však můžete nechat náhrady připsat předem nastavenému uživateli – například účtu robota – přidáním řádku jako je tento do LocalSettings.php pod zahrnutím Replace Text:

Zadané uživatelské jméno již musí mít účet na wiki. Bude přidáno do pole MediaWiki s uživatelskými jmény, ve kterých nemusí být zaregistrováno nebo přihlášeno.

Autoři
Replace Text was mostly written by Yaron Koren, reachable at yaron57@undefinedgmail.com. Important contributions were also made by Niklas Laxström, Ankit Garg (who contributed much of the regular expression code), Mark Hershberger (who wrote the command-line script), Brent Laabs, Cindy Cicalese, Nikhil Kumar, Umherirrender, James Forrester, Fomafix, Marijn van Wezel, Sahaj Khandelwal and others. 

Historie verzí
Replace Text is currently at version 1.7. See the entire version history.

Snímky obrazovky
Níže jsou obrázky pracovního postupu Replace Text. First, the initial page in which "George F. Will" and "George Will" are entered for the target string and replacement string, respectively, and replacing text in page titles is specified as well, on Discourse DB:



Note: the check "All" and "None" boxes only show up when using the Vector skin, or skins based off of it.

And here is what the page looks like after the user hits "Continue":



Hitting "Replace" would replace this value in all of the listed pages, as well as moving the page at the end to its new value.



Známé problémy

 * The replacement actions themselves are structured as MediaWiki "jobs", to ensure that the system is not overloaded if the user wants to do many at the same time. This means that a large set of replacements will not be done immediately, and may take minutes, hours or even longer to complete. Normally, jobs get activated every time a page is viewed on the wiki; to speed up the process (or slow it down), you can change the number of jobs run when a page is viewed; the default is 1. Thus a Replace Text request can stall soon after it starts if there is not enough front-end activity on the wiki to outrun the other sources of new batch jobs. For information on how to change the default, see the  page. To force the wiki to run all jobs immediately, go to the shell and execute the script ; there generally isn't a way to do this from the wiki's front end.
 * For getting the jobs to run on a seldom-used wiki, for instance a working wiki for a small hobby project team, you can for instance force a refresh of the "All pages" special page. This can be done for instance by using the following shell script on Unix:
 * If you are still having a problem with getting Replace Text's jobs to run, adding the following to LocalSettings.php may fix the problem:
 * If you are still having a problem with getting Replace Text's jobs to run, adding the following to LocalSettings.php may fix the problem:


 * In order for redirects not to be created on page moves (i.e. if the "Save the old titles as redirects to the new titles" checkbox is unchecked), you will have to give the relevant user the 'suppressredirect' permission. Assuming you've given the 'replacetext' permission to a "trusted-editor" user group, you would need to add the following to LocalSettings.php:


 * If your revisions are compressed (that is, if is enabled in  or the script  has been executed with the option  ) then ReplaceText will not work, because it makes use of SQL queries that can't search compressed text. (see the MassEditRegex extension as an alternative in this case.)
 * If you have a large number of replacements, some of them may not get done; or you may see an error message that reads "You must select at least one namespace." In both cases, that's due to a limit on the number of form inputs that PHP accepts. This can be fixed in a number of ways:
 * If you have the Suhosin PHP extension installed on your server, that may be source of the problem. You can increase the value of the variables  and  ; or simply try temporarily disabling Suhosin while you do the replacements.
 * The PHP setting  (available since PHP 5.3.9) also affects the number of replacements you can do at any time - you can try setting this to a very large number, like 3000.

Překlad
Translation of Replace Text is done through translatewiki.net. The translation for this extension can be found here. To add language values or change existing ones, you should create an account on translatewiki.net, then request permission from the administrators to translate a certain language or languages on this page (this is a very simple process). Once you have permission for a given language, you can log in and add or edit whatever messages you want to in that language.



Související odkazy

 * Extension:MassEditRegex - A similar extension using regular expressions to edit multiple pages at once