La funzione ricerca in testo i criteri
impostati in espressione_regolare. Se
riconosce dei testi, li sostituisce con sostituto.
Se si specifica limite, verranno sostituiti
solamente limite testi riconosciuti;
se viene omesso, oppure impostato a -1, verranno sostituiti tutti
i testi riconosciuti.
Il parametro sostituto può contenere riferimenti
nella forma di \\n, oppure,
a partire dalla versione 4.0.4 di PHP, $n, con la preferenza per la seconda sintassi. Questo tipo di
riferimento verrà sostituito dal testo che soddisfa l'n
-esimo criterio presente in espressione_regolare
. Sono ammessi numeri compresi tra 0 e 99 inclusi. Il valore 0
(\\0 oppure $0) si riferisce al testo
riconosciuto tramite tutta l'espressione regolare passata. Nel conteggio
dei criteri di riconoscimento presenti, sono contate le parentesi
aperte da sinistra verso destra partendo da 1.
Quando si lavora con un criterio di sostituzione in cui un riferimento all'indietro
è immediatamente seguito da un'altro numero (ad esempio un numero che segue immediatamente
il criterio riconosciuto), non si possono utilizzare le solite notazioni, \\1,
per i riferimenti all'indietro. Ad esempio, il testo \\11
confonderebbe preg_replace() poiché non saprebbe se si desidera il riferimento
all'indietro \\1 seguito dal numero 1, oppure
se è desiderato il riferimento \\11 seguito da niente. In questi
casi la soluzione consiste nell'uso di \${1}1. In questo modo si
crea un riferimento all'indietro $1 isolato dal numero 1.
Example #1 Uso dei riferimenti all'indietro seguiti da numeri
Se verranno riconosciuti dei testi, la funzione restituisce la nuova
versione di testo, altrimenti il parametro
sarà restituito inalterato.
Ogni parametro passato alla funzione preg_replace(),
(eccetto limite) può essere una matrice ad una dimensione.
Quando si utilizzano matrici con espressione_regolare
e sostituto, le chiavi sono processate
nell'ordine con cui appaiono nella matrice. Questo
non è necessariamente l'ordine
numerico dell'indice. Se si utilizzano degli indici per
identificare quale espressione_regolare debba
essere sostituita da sostituto, occorre eseguire
la funzione ksort() su ciascuna matrice
prima di eseguire preg_replace().
Example #2 Uso di matrici indicizzate con preg_replace()
<?php $string = "The quick brown fox jumped over the lazy dog.";
Se il campo testo è una matrice, la ricerca
e la sostituzione sarà eseguita su ogni elemento della matrice,
e conseguentemente la funzione restituirà una matrice.
Se espressione_regolare ed sostituto
sono entrambi delle matrici, la funzione preg_replace()
utilizza gli elementi di ciascuna matrice per la ricerca e la sostituzione
delle stringhe in testo. Nel caso in cui la
matrice passata in sostituto abbia
meno elementi che espressione_regolare,
la funzione utilizzerà una stringa vuota per compensare gli
elementi mancanti nella fase di sostituzione. Se, invece,
espressione_regolare è una matrice,
mentre il campo sostituto è una stringa,
quest'ultima sarà usata come valore da sostituire ad ogni testo
riconosciuto. Un discorso contrario non ha senso.
Il modificatore /e, permette alla funzione
di considerare il testo posto in sostituto
come codice PHP dopo aver valorizzato gli opportuni riferimenti.
Suggerimento: accertarsi che sostituto
sia del codice PHP valido, altrimenti si ottiene un errore di
parsing alla linea della funzione preg_replace().
Nell'esempio precedente tutti i tag HTML presenti nel testo di
input saranno convertiti in maiuscolo.
Example #5 Esempio di conversione di codice HTML in testo
<?php // $document contiene un documento HTML. // In questo esempio la funzione rimuove i tag HTML, // le sezioni javascript e gli spazi bianchi. // Inoltre si convertirà le entità HTML nella loro // rappresentazione testuale. $search = array ("'<script[^>]*?>.*?</script>'si", // Rimozione del javascript "'<[\/\!]*?[^<>]*?>'si", // Rimozione dei tag HTML "'([\r\n])[\s]+'", // Rimozione degli spazi bianchi "'&(quot|#34);'i", // Sostituzione delle entità HTML "'&(amp|#38);'i", "'&(lt|#60);'i", "'&(gt|#62);'i", "'&(nbsp|#160);'i", "'&(iexcl|#161);'i", "'&(cent|#162);'i", "'&(pound|#163);'i", "'&(copy|#169);'i", "'&#(\d+);'e"); // Valuta come codice PHP
The following should be escaped if you are trying to match that character
\ ^ . $ | ( ) [ ] * + ? { } ,
Special Character Definitions \ Quote the next metacharacter ^ Match the beginning of the line . Match any character (except newline) $ Match the end of the line (or before newline at the end) | Alternation () Grouping [] Character class * Match 0 or more times + Match 1 or more times ? Match 1 or 0 times {n} Match exactly n times {n,} Match at least n times {n,m} Match at least n but not more than m times More Special Character Stuff \t tab (HT, TAB) \n newline (LF, NL) \r return (CR) \f form feed (FF) \a alarm (bell) (BEL) \e escape (think troff) (ESC) \033 octal char (think of a PDP-11) \x1B hex char \c[ control char \l lowercase next char (think vi) \u uppercase next char (think vi) \L lowercase till \E (think vi) \U uppercase till \E (think vi) \E end case modification (think vi) \Q quote (disable) pattern metacharacters till \E Even More Special Characters \w Match a "word" character (alphanumeric plus "_") \W Match a non-word character \s Match a whitespace character \S Match a non-whitespace character \d Match a digit character \D Match a non-digit character \b Match a word boundary \B Match a non-(word boundary) \A Match only at beginning of string \Z Match only at end of string, or before newline at the end \z Match only at end of string \G Match only where previous m//g left off (works only with /g)
You can only use numeric backreferences in the replacement string, but not named ones: <?php echo preg_replace('#(\d+)#', '\1 $1 ${1}', '123'); // 123 123 123 echo preg_replace('#(?<digits>\d+)#', '\digits $digits ${digits}', '123'); // \digits $digits ${digits} ?>
To use named backreferences, you have to use preg_replace_callback: <?php echo preg_replace_callback('#(?<digits>\d+)#', function( $m ){ return "$m[1]$m[digits]{$m['digits']}"; }, '123'); // 123 123 123
To split Pascal/CamelCase into Title Case (for example, converting descriptive class names for use in human-readable frontends), you can use the below function:
Be aware that when using the "/u" modifier, if your input text contains any bad UTF-8 code sequences, then preg_replace will return an empty string, regardless of whether there were any matches.
This is due to the PCRE library returning an error code if the string contains bad UTF-8.
From what I can see, the problem is, that if you go straight and substitute all 'A's wit 'T's you can't tell for sure which 'T's to substitute with 'A's afterwards. This can be for instance solved by simply replacing all 'A's by another character (for instance '_' or whatever you like), then replacing all 'T's by 'A's, and then replacing all '_'s (or whatever character you chose) by 'A's:
<?php
$dna = "AGTCTGCCCTAG";
echo str_replace(array("A","G","C","T","_","-"), array("_","-","G","A","T","C"), $dna); //output will be TCAGACGGGATC
?>
Although I don't know how transliteration in perl works (though I remember that is kind of similar to the UNIX command "tr") I would suggest following function for "switching" single chars:
Below is a function for converting Hebrew final characters to their normal equivelants should they appear in the middle of a word. The /b argument does not treat Hebrew letters as part of a word, so I had to work around that limitation.
do { $text_before=$text; $text=hebrewNotWordEndSwitch("ך","כ",$text); $text=hebrewNotWordEndSwitch("ם","מ",$text); $text=hebrewNotWordEndSwitch("ן","נ",$text); $text=hebrewNotWordEndSwitch("ף","פ",$text); $text=hebrewNotWordEndSwitch("ץ","צ",$text); } while ( $text_before!=$text );
print $text; // עברית מסודרת!
?>
The do-while is necessary for multiple instances of letters, such as "אנני" which would start off as "אןןי". Note that there's still the problem of acronyms with gershiim but that's not a difficult one to solve. The code is in use at http://gibberish.co.il which you can use to translate wrongly-encoded Hebrew, transliterize, and some other Hebrew-related functions.
To ensure that there will be no regular characters at the end of a word, just convert all regular characters to their final forms, then run this function. Enjoy!
is;huge ======================================================================= visualizing in a hex viewer .. to_check_with_a_hex_viewer.txt ... t h i s ; LF TAB n o p e CR LF CR LF i s ; h u g e CR LF 74 68 69 73 3b 0a 09 6e 6f 70 65 0d 0a 0d 0a 69 73 3b 68 75 67 65 0d 0a I used F3 (viewer + options 3: hex) in mythical TOTAL COMMANDER! ======================================================================= */
The used short-codes are purely used for educational purposes for they could be shorter as in 'italic' to 'i' or 'bold' to 'b'.
Sample text ---- This sample shows how to have [italic]italic[/italic], [bold]bold[/bold] and [underline]underlined[/underline] and [strikethrough]striked[/striketrhough] text.