File: a2249.html

package info (click to toggle)
appunti-informatica-libera 2001.08.18-2
  • links: PTS
  • area: main
  • in suites: woody
  • size: 27,912 kB
  • ctags: 23,734
  • sloc: makefile: 69
file content (555 lines) | stat: -rw-r--r-- 35,294 bytes parent folder | download
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"    "http://www.w3.org/TR/html4/strict.dtd">
<HTML LANG="it">
<HEAD>
    <META HTTP-EQUIV="Content-Type" CONTENT="text/html">
    <META NAME="Generator" CONTENT="Alml">
    <META NAME="Description" CONTENT="GNU/Linux e altro software libero">
    <META NAME="Keywords" CONTENT="Linux, GNU/Linux, Unix, software, software libero, free software">
    <META NAME="Author" CONTENT="Daniele Giacomini &nbsp;&nbsp; &nbsp;daniele&nbsp;@&nbsp;swlibero.org">
    <META NAME="Date" CONTENT="2001.08.18 ">
    <META NAME="Resource-type" LANG="en" CONTENT="Document" >
    <META NAME="Revisit-after" LANG="en" CONTENT="15 days" >
    <META NAME="Robots" CONTENT="ALL" >
    <TITLE> Appunti di informatica libera</TITLE>
    <LINK REL="stylesheet" TYPE="text/css" HREF="a2.css">
    <LINK REL="Start" TITLE="Start" HREF="a2.html">
    <LINK REL="Prev" TITLE="Previous" HREF="a2248.html">
    <LINK REL="Next" TITLE="Next" HREF="a2250.html">
</HEAD>
<BODY>
<P>
<A HREF="a2250.html">[successivo]</A>
<A HREF="a2248.html">[precedente]</A>
<A HREF="a2.html">[inizio]</A>
<A HREF="a2506.html">[fine]</A>
<A HREF="a21.html">[indice generale]</A>
<A HREF="a26.html">[violazione GPL]</A>
<A HREF="a2504.html">[licenze]</A>
<A HREF="a2505.html">[indice analitico]</A>
<A HREF="a2230.html">[tomo]</A>
<A HREF="a2247.html">[parte]</A>
</P>
<HR>
<DIV>
<H1>Capitolo 191. &nbsp; <A NAME="title3098"></A><A NAME="anchor3787"></A> <A NAME="index16269"></A>Perl: gestione delle stringhe <A NAME="index16270"></A> </H1>

<P>La gestione delle stringhe da parte di <A NAME="index16271"></A>Perl &egrave; fatta attraverso gli operatori di delimitazione delle stringhe stesse e le <A NAME="index16272"></A>espressioni regolari. &Egrave; questo insieme di cose che rende <A NAME="index16273"></A>Perl uno strumento valido per la gestione dei file di testo.</P>

<H2>191.1 &nbsp; <A NAME="title3099"></A><A NAME="anchor3788"></A>
 Operatori di delimitazione di stringhe </H2>

<P>Nella sezione dedicata agli operatori e alle espressioni erano rimasti in sospeso gli operatori di delimitazione di stringhe. Nei linguaggi di programmazione tradizionale esiste normalmente il problema di delimitare le stringhe, ovvero le costanti alfanumeriche. Sono gi&agrave; stati mostrati due tipi di delimitatori, gli apici doppi e singoli che hanno un comportamento simile a quello delle <A NAME="index16274"></A>shell comuni. In realt&agrave; <A NAME="index16275"></A>Perl ha una gestione molto pi&ugrave; raffinata e generalizzata delle stringhe. Quando il tipo di delimitazione, ovvero il tipo di stringa, lo consente, sono validi alcuni codici di <A NAME="index16276"></A>escape. La tabella <A HREF="a2249.html#anchor3789">191.1</A> mostra l'elenco di queste sequenze di <A NAME="index16277"></A>escape utilizzabili nelle stringhe.</P>

<TABLE ID="anchor3789" BORDER="3">

<THEAD>
<TR><TD>Escape </TD><TD>Corrispondenza </TD></TR>
</THEAD>

<TBODY>
<TR><TD>\\ </TD><TD>\ </TD></TR>
<TR><TD>\" </TD><TD>" </TD></TR>
<TR><TD>\$ </TD><TD>$ </TD></TR>
<TR><TD>\@ </TD><TD>@ </TD></TR>
<TR><TD>\' </TD><TD>' </TD></TR>
<TR><TD>\t </TD><TD>&lt;<EM>HT</EM>&gt; </TD></TR>
<TR><TD>\n </TD><TD>&lt;<EM>LF</EM>&gt; </TD></TR>
<TR><TD>\r </TD><TD>&lt;<EM>CR</EM>&gt; </TD></TR>
<TR><TD>\f </TD><TD>&lt;<EM>FF</EM>&gt; </TD></TR>
<TR><TD>\a </TD><TD>&lt;<EM>BEL</EM>&gt; </TD></TR>
<TR><TD>\e </TD><TD>&lt;<EM>ESC</EM>&gt; </TD></TR>
<TR><TD>\0<VAR>n</VAR> </TD><TD>Numero ottale rappresentato da <VAR>n</VAR>. </TD></TR>
<TR><TD>\x<VAR>h</VAR> </TD><TD>Numero esadecimale rappresentato da <VAR>h</VAR>. </TD></TR>
<TR><TD>\[ </TD><TD>Carattere di controllo. </TD></TR>
<TR><TD>\l </TD><TD>Il carattere successivo in minuscolo. </TD></TR>
<TR><TD>\u </TD><TD>Il carattere successivo in maiuscolo. </TD></TR>
<TR><TD>\L </TD><TD>Minuscolo fino al codice <SAMP>\E</SAMP>. </TD></TR>
<TR><TD>\U </TD><TD>Maiuscolo fino al codice <SAMP>\E</SAMP>. </TD></TR>
<TR><TD>\E </TD><TD>Conclusione di un modificatore. </TD></TR>
<TR><TD>\Q </TD><TD>Evita l'interpretazione come <A NAME="index16279"></A>espressione regolare fino al codice <SAMP>\E</SAMP>. </TD></TR>
</TBODY>
</TABLE>

<P><EM> Tabella <A HREF="a2249.html#anchor3789">191.1</A>. Elenco delle sequenze di <A NAME="index16278"></A>escape utilizzabili nelle stringhe delimitate con gli apici doppi. </EM></P>

<P>La delimitazione dei vari tipi di stringa avviene in una forma tradizionale, attraverso delimitatori che esprimono di per s&eacute; il tipo di stringa, oppure attraverso una forma che consente di cambiare tipo di delimitatore:</P>

<P class="syntax"><TT><VAR>x</VAR><VAR>delim_sinistro</VAR><VAR>stringa</VAR><VAR>delim_destro</VAR><VAR>eventuali_opzioni</VAR>
</TT></P>

<P>La sigla che appare inizialmente, <VAR>x</VAR> in questo caso, definisce il tipo di stringa; il delimitatore sinistro e quello destro possono essere parentesi aperte e chiuse di qualunque tipo: tonde, quadre, graffe e angolari, ma si possono utilizzare anche altri simboli, solo che in tal caso, il delimitatore sinistro e quello destro saranno uguali.</P>

<P>La tabella <A HREF="a2249.html#anchor3800">191.5</A>, alla fine di questo gruppo di sezioni, riassume i vari tipi di operatori di delimitazione delle stringhe.</P>

<H3>191.1.1 &nbsp; <A NAME="title3100"></A><A NAME="anchor3790"></A>
 q | ' ' -- stringa letterale non interpolata <A NAME="index16280"></A> </H3>

<P>Si tratta della stringa racchiusa normalmente tra apici singoli. &Egrave; gi&agrave; stata descritta in precedenza. In particolare, restituisce la stringa racchiusa senza effettuare l'interpolazione delle eventuali variabili e dei simboli di <A NAME="index16281"></A>escape che dovesse incorporare, a eccezione di <SAMP>\'</SAMP> e <SAMP>\\</SAMP>. Si pu&ograve; esprimere in due modi.</P>

<P class="syntax"><TT>'<VAR>stringa</VAR>'
</TT></P>

<P class="syntax"><TT>q<VAR>delim_sinistro</VAR><VAR>stringa</VAR><VAR>delim_destro</VAR>
</TT></P>

<P>Seguono alcuni esempi.</P>

<PRE>$miavar = 'Stringa tradizionale che non interpola';

$miavar = q|Una stringa che "contiene 'apici' di ogni tipo".|;

$miavar = q(Sembra una funzione, ma non lo &egrave;);

$miavar = q{Le variabili non vengono interpolate. $ciao};</PRE>

<H3>191.1.2 &nbsp; <A NAME="title3101"></A><A NAME="anchor3791"></A>
 qq | " " -- stringa letterale interpolata <A NAME="index16282"></A> </H3>

<P>Si tratta della stringa racchiusa normalmente tra apici doppi. &Egrave; gi&agrave; stata descritta in precedenza. In particolare, restituisce la stringa racchiusa interpolando le variabili e i simboli di <A NAME="index16283"></A>escape che dovesse incorporare. Si pu&ograve; esprimere in due modi.</P>

<P class="syntax"><TT>"<VAR>stringa</VAR>"
</TT></P>

<P class="syntax"><TT>qq<VAR>delim_sinistro</VAR><VAR>stringa</VAR><VAR>delim_destro</VAR>
</TT></P>

<P>Seguono alcuni esempi.</P>

<PRE>$miavar = "Stringa tradizionale che interpola";

$miavar = qq|Una stringa che \"contiene 'apici' di ogni tipo\".|;

$miavar = qq(Sembra una funzione, ma non lo &egrave;);

$ciao = "Saluti!";
$miavar = qq{Le variabili vengono interpolate. $ciao};</PRE>

<H3>191.1.3 &nbsp; <A NAME="title3102"></A><A NAME="anchor3792"></A>
 qx | ` ` -- comando di sistema <A NAME="index16284"></A> </H3>

<P>Si tratta di stringhe il cui contenuto deve essere valutato e successivamente eseguito come comando dal sistema operativo. Questo tipo di stringa &egrave; racchiuso normalmente tra apici singoli inversi, come avviene nelle <A NAME="index16285"></A>shell comuni. Il contenuto della stringa viene interpolato prima dell'esecuzione del comando. La valutazione della stringa si traduce nell'output emesso attraverso lo <A NAME="index16286"></A>standard output dal comando stesso. Si pu&ograve; esprimere in due modi.</P>

<P class="syntax"><TT>`<VAR>stringa</VAR>`
</TT></P>

<P class="syntax"><TT>qx<VAR>delim_sinistro</VAR><VAR>stringa</VAR><VAR>delim_destro</VAR>
</TT></P>

<P>Seguono alcuni esempi.</P>

<PRE>$miadata = `date`;

$mioelenco = qx(ls);

$opzioni = '-l'
$mioelenco = qx{ls $opzioni};</PRE>

<H3>191.1.4 &nbsp; <A NAME="title3103"></A><A NAME="anchor3793"></A>
 qw -- lista di parole <A NAME="index16287"></A> </H3>

<P>La stringa racchiusa in questo tipo di delimitazione, non viene interpolata, ma semplicemente restituita in forma di <STRONG><EM>lista di parole</EM></STRONG>. In pratica, tutto ci&ograve; che risulta separato da spazi (spazi veri e propri, caratteri di tabulazione e <A NAME="index16288"></A>codici di interruzione di riga) viene estratto e inserito in una lista di elementi. Si pu&ograve; esprimere solo nel modo seguente:</P>

<P class="syntax"><TT>qw<VAR>delim_sinistro</VAR><VAR>stringa</VAR><VAR>delim_destro</VAR>
</TT></P>

<P>Seguono alcuni esempi validi.</P>

<PRE>@mialista = qw/ciao come stai/;

@mialista = qw(uno      due     tre);

@mialista = qw(alfa     bravo   charlie
delta   echo    foxtrot golf    hotel
india   kilo    lima);</PRE>

<H3>191.1.5 &nbsp; <A NAME="title3104"></A><A NAME="anchor3794"></A>
 m | // -- modello di confronto <A NAME="index16289"></A> </H3>

<P>Definisce un modello di confronto con una stringa. Non restituisce alcunch&eacute;; serve per essere paragonato a un'altra stringa. Pu&ograve; essere usato in un contesto scalare o lista. Nel primo caso serve a determinare se esiste una corrispondenza con il modello o meno. Nel secondo caso, viene sempre paragonato a un'altra stringa, ma il risultato di questo abbinamento &egrave; una lista di elementi.</P>

<P>Il modello si esprime in forma di <A NAME="index16290"></A>espressione regolare, con delle particolarit&agrave; che derivano dal tipo di delimitatori utilizzati e dal fatto che prima di valutare l'<A NAME="index16291"></A>espressione regolare viene eseguita un'interpolazione. Si pu&ograve; esprimere in due modi.</P>

<P class="syntax"><TT>/<VAR>stringa</VAR>/<VAR>opzioni</VAR>
</TT></P>

<P class="syntax"><TT>m<VAR>delim_sinistro</VAR><VAR>stringa</VAR><VAR>delim_destro</VAR><VAR>modificatori</VAR>
</TT></P>

<P>I modificatori si esprimono con una serie di lettere, o nulla se non &egrave; necessario. La tabella <A HREF="a2249.html#anchor3795">191.2</A> ne riporta l'elenco.</P>

<TABLE ID="anchor3795" BORDER="3">

<THEAD>
<TR><TD>Modificatore </TD><TD>Descrizione </TD></TR>
</THEAD>

<TBODY>
<TR><TD>i </TD><TD>Il confronto avviene ignorando la differenza tra maiuscole e minuscole. </TD></TR>
<TR><TD>m </TD><TD>Le stringhe vengono trattate come righe multiple (riguarda <SAMP>^</SAMP> e <SAMP>$</SAMP>). </TD></TR>
<TR><TD>s </TD><TD>Tratta le stringhe come una riga singola (riguarda <SAMP>.</SAMP>). </TD></TR>
<TR><TD>x </TD><TD>Permette l'inserzione di spazi e commenti che non vengono interpretati. </TD></TR>
<TR><TD>g </TD><TD>Confronta in modo globale, cio&egrave; trova tutte le occorrenze. </TD></TR>
<TR><TD>o </TD><TD>Interpreta il modello (e di conseguenza lo interpola) solo la prima volta. </TD></TR>
</TBODY>
</TABLE>

<P><EM> Tabella <A HREF="a2249.html#anchor3795">191.2</A>. Elenco dei modificatori utilizzabili con l'operatore di delimitazione <SAMP>m</SAMP>. </EM></P>

<TABLE BORDER="3" WIDTH="100%">
<TR><TD>

<P>L'utilizzo delle <A NAME="index16292"></A>espressioni regolari nelle istruzioni <A NAME="index16293"></A>Perl &egrave; ci&ograve; che generalmente rende il sorgente di un programma piuttosto confuso. Se si devono utilizzare intensivamente le <A NAME="index16294"></A>espressioni regolari sarebbe opportuno approfondirne il funzionamento e l'utilizzo di questo tipo di delimitatori, per trovare un modo meno complicato del solito di scrivere queste espressioni. Il primo punto su cui si pu&ograve; intervenire &egrave; la scelta dei simboli di delimitazione. La forma tradizionale prevede l'uso della barra obliqua normale, cosa per&ograve; che crea problemi quando si vuole utilizzare questo simbolo all'interno dell'espressione stessa. Infatti, i simboli usati come delimitazione non possono essere utilizzati nell'<A NAME="index16295"></A>espressione regolare senza la tecnica della protezione per mezzo del prefisso <SAMP>\</SAMP>.</P>

</TD></TR>
</TABLE>

<DL>
<DT><STRONG>Esempi</STRONG></DT>
<DD>

<PRE>#!/usr/bin/perl

$miafrase = 'Ciao, come stai?';
if ($miafrase =~ /ciao/i)
  {
    print "Ciao!\n";
  }</PRE>

<P>In questo esempio, il modello <CODE>/ciao/i</CODE> combacia con una parte della frase, facendo s&igrave; che la condizione si avveri.</P>

<PRE>#!/usr/bin/perl

$mioelenco = `ls`;
if ($mioelenco =~ /.*\.pl/)
  {
    print "Ci sono programmi Perl in questa directory.\n";
  }</PRE>

<P>In questo esempio, viene letto il contenuto della directory corrente e posto nella variabile <SAMP>$mioelenco</SAMP>. Successivamente viene verificato se in quell'elenco si trova qualcosa che termina con <CODE>.pl</CODE>. Dal momento che il punto ha un significato nelle <A NAME="index16296"></A>espressioni regolari, per poterlo includere si &egrave; posta anteriormente una barra obliqua inversa.</P>
</DD>
</DL>

<H3>191.1.6 &nbsp; <A NAME="title3105"></A><A NAME="anchor3796"></A>
 s -- modello di sostituzione <A NAME="index16297"></A> </H3>

<P>Definisce un modello di confronto con una stringa, e una stringa di sostituzione per la parte che corrisponde al modello. Se il confronto non viene fatto attraverso gli operatori <SAMP>=~</SAMP> oppure <SAMP>!~</SAMP>, si intende che l'abbinamento avvenga con il contenuto della variabile <SAMP>$_</SAMP>. Ha luogo l'interpolazione.</P>

<P>L'abbinamento per la sostituzione pu&ograve; avvenire solo in un contesto scalare. Il modello si esprime in forma di <A NAME="index16298"></A>espressione regolare. La sintassi pu&ograve; essere espressa in due modi, a seconda del tipo di delimitatori utilizzati.</P>

<P class="syntax"><TT>s<VAR>delim_sx</VAR><VAR>stringa</VAR><VAR>delim_dx</VAR><VAR>delim_sx</VAR><VAR>rimpiazzo</VAR><VAR>delim_dx</VAR><VAR>modificatori</VAR>
</TT></P>

<P class="syntax"><TT>s<VAR>delim</VAR><VAR>stringa</VAR><VAR>delim</VAR><VAR>rimpiazzo</VAR><VAR>delim</VAR><VAR>modificatori</VAR>
</TT></P>

<P>Il primo tipo di sintassi si adatta al caso in cui si usino parentesi per delimitare le stringhe del modello e del rimpiazzo, il secondo tipo si riferisce all'uso di altri simboli che non sono utilizzati in coppia.</P>

<P>I modificatori si esprimono con una serie di lettere, o nulla se ci&ograve; non &egrave; necessario. La tabella <A HREF="a2249.html#anchor3797">191.3</A> ne riporta l'elenco.</P>

<TABLE ID="anchor3797" BORDER="3">

<THEAD>
<TR><TD>Modificatore </TD><TD>Descrizione </TD></TR>
</THEAD>

<TBODY>
<TR><TD>i </TD><TD>Il confronto avviene ignorando la differenza tra maiuscole e minuscole. </TD></TR>
<TR><TD>m </TD><TD>Le stringhe vengono trattate come righe multiple (riguarda <SAMP>^</SAMP> e <SAMP>$</SAMP>). </TD></TR>
<TR><TD>s </TD><TD>Tratta le stringhe come una singola riga (riguarda <SAMP>.</SAMP>). </TD></TR>
<TR><TD>x </TD><TD>Permette l'inserzione di spazi e commenti che non vengono interpretati. </TD></TR>
<TR><TD>g </TD><TD>Confronta in modo globale, cio&egrave; trova tutte le occorrenze. </TD></TR>
<TR><TD>o </TD><TD>Interpreta il modello (e di conseguenza lo interpola) solo la prima volta. </TD></TR>
<TR><TD>e </TD><TD>Valuta la parte destra come un'espressione. </TD></TR>
</TBODY>
</TABLE>

<P><EM> Tabella <A HREF="a2249.html#anchor3797">191.3</A>. Elenco dei modificatori utilizzabili con l'operatore di delimitazione <SAMP>s</SAMP>. </EM></P>

<DL>
<DT><STRONG>Esempi</STRONG></DT>
<DD>

<PRE>$path =~ s|/usr/bin|/usr/local/bin|</PRE>

<P>Sostituisce la prima occorrenza di <CODE>/usr/bin</CODE> nella variabile <SAMP>$path</SAMP> con <CODE>/usr/local/bin</CODE>. Per delimitare il modello e la stringa di sostituzione sono state usate le barre verticali, per evitare ambiguit&agrave; con le barre oblique delle directory.</P>

<PRE>$path =~ s{/usr/bin}{/usr/local/bin}</PRE>

<P>Esattamente come nell'esempio precedente, ma questa volta sono state usate le parentesi graffe.</P>
</DD>
</DL>

<H3>191.1.7 &nbsp; <A NAME="title3106"></A><A NAME="anchor3798"></A>
 tr | y -- traslazione di caratteri <A NAME="index16299"></A> <A NAME="index16300"></A> </H3>

<P>Definisce un modello di sostituzione di una serie di caratteri in un'altra. Si applica al contenuto di una variabile scalare utilizzando l'operatore <SAMP>=~</SAMP> oppure <SAMP>!~</SAMP>, altrimenti si intende la variabile <SAMP>$_</SAMP>. Restituisce il numero di trasformazioni eseguite. Non ha luogo l'interpolazione.</P>

<P>L'abbinamento per la sostituzione pu&ograve; avvenire solo in un contesto scalare. Il modello si esprime in forma di <A NAME="index16301"></A>espressione regolare. La sintassi pu&ograve; essere espressa nei modi seguenti, a seconda che si voglia utilizzare l'identificatore <SAMP>tr</SAMP> o <SAMP>y</SAMP> e a seconda del tipo di delimitatori utilizzati.</P>

<P class="syntax"><TT>tr<VAR>delim_sx</VAR><VAR>car_da_sost</VAR><VAR>delim_dx</VAR><VAR>delim_sx</VAR><VAR>rimpiazzo</VAR><VAR>delim_dx</VAR><VAR>modificatori</VAR>
</TT></P>

<P class="syntax"><TT>tr<VAR>delim</VAR><VAR>car_da_sostituire</VAR><VAR>delim</VAR><VAR>rimpiazzo</VAR><VAR>delim</VAR><VAR>modificatori</VAR>
</TT></P>

<P class="syntax"><TT>y<VAR>delim_sx</VAR><VAR>car_da_sost</VAR><VAR>delim_dx</VAR><VAR>delim_sx</VAR><VAR>rimpiazzo</VAR><VAR>delim_dx</VAR><VAR>modificatori</VAR>
</TT></P>

<P class="syntax"><TT>y<VAR>delim</VAR><VAR>car_da_sostituire</VAR><VAR>delim</VAR><VAR>rimpiazzo</VAR><VAR>delim</VAR><VAR>modificatori</VAR>
</TT></P>

<P>I modificatori si esprimono con una serie di lettere, o nulla se ci&ograve; non &egrave; necessario. La tabella <A HREF="a2249.html#anchor3799">191.4</A> ne riporta l'elenco.</P>

<TABLE ID="anchor3799" BORDER="3">

<THEAD>
<TR><TD>Modificatore </TD><TD>Descrizione </TD></TR>
</THEAD>

<TBODY>
<TR><TD>c </TD><TD>Cerca gli elementi che <STRONG>non</STRONG> sono elencati nel gruppo da sostituire. </TD></TR>
<TR><TD>d </TD><TD>Cancella i caratteri trovati e non rimpiazzati. </TD></TR>
<TR><TD>s </TD><TD>Fonde insieme i caratteri doppi che sono stati ritrovati. </TD></TR>
</TBODY>
</TABLE>

<P><EM> Tabella <A HREF="a2249.html#anchor3799">191.4</A>. Elenco dei modificatori utilizzabili con l'operatore di delimitazione <SAMP>tr</SAMP>. </EM></P>

<TABLE ID="anchor3800" BORDER="3">

<THEAD>
<TR><TD>Formato normale </TD><TD>Formato generico </TD><TD>Significato </TD><TD>Interpolazione </TD></TR>
</THEAD>

<TBODY>
<TR><TD>' ' </TD><TD>q{} </TD><TD>Stringa letterale. </TD><TD>NO </TD></TR>
<TR><TD>" " </TD><TD>qq{} </TD><TD>Stringa letterale. </TD><TD>S&Igrave; </TD></TR>
<TR><TD>` ` </TD><TD>qx{} </TD><TD>Comando di sistema. </TD><TD>S&Igrave; </TD></TR>
<TR><TD> </TD><TD>qw{} </TD><TD>Lista di parole. </TD><TD>NO </TD></TR>
<TR><TD>/ / </TD><TD>m{} </TD><TD>Modello di confronto. </TD><TD>S&Igrave; </TD></TR>
<TR><TD> </TD><TD>s{}{} </TD><TD>Modello di sostituzione. </TD><TD>S&Igrave; </TD></TR>
<TR><TD> </TD><TD>tr{}{} </TD><TD>Traslazione di caratteri. </TD><TD>S&Igrave; </TD></TR>
</TBODY>
</TABLE>

<P><EM> Tabella <A HREF="a2249.html#anchor3800">191.5</A>. Elenco riassuntivo dei tipi di operatori di stringa. Le parentesi graffe rappresentano la posizione dei delimitatori. </EM></P>

<DL>
<DT><STRONG>Esempi</STRONG></DT>
<DD>

<PRE>$miavar =~ tr/A-Z/a-z/;</PRE>

<P>Converte in minuscolo il contenuto della variabile (a parte le vocali accentate).</P>

<PRE>$contatore = ($miavar =~ tr/0-9//);</PRE>

<P>Conta i caratteri numerici contenuti nella variabile <SAMP>$miavar</SAMP>.</P>
</DD>
</DL>

<H2>191.2 &nbsp; <A NAME="title3107"></A><A NAME="anchor3801"></A>
 <A NAME="index16302"></A>Espressioni regolari <A NAME="index16303"></A> <A NAME="index16304"></A> </H2>

<P>Le <A NAME="index16305"></A>espressioni regolari possono essere considerate l'elemento pi&ugrave; potente e pi&ugrave; difficile di <A NAME="index16306"></A>Perl. Purtroppo non esiste una definizione e uno standard universale delle <A NAME="index16307"></A>espressioni regolari, cos&igrave;, per ogni applicazione che ne fa uso occorre studiarne le particolarit&agrave;.</P>

<P>In questa sezione si descrive solo parte delle potenzialit&agrave; di <A NAME="index16308"></A>Perl con le <A NAME="index16309"></A>espressioni regolari. Per conoscerne i dettagli &egrave; necessario consultare la <A NAME="index16310"></A>pagina di manuale <EM>perlre</EM>(1). Pu&ograve; essere conveniente anche la lettura della sezione <A HREF="a296.html#anchor1355">68.1</A> e del capitolo <A HREF="a2276.html#anchor4215">211</A>.</P>

<H3>191.2.1 &nbsp; <A NAME="title3108"></A><A NAME="anchor3802"></A>
 Modificatori </H3>

<P><A NAME="index16311"></A>Perl utilizza le <A NAME="index16312"></A>espressioni regolari con gli operatori di stringa <SAMP>m{}</SAMP> e <SAMP>s{}{}</SAMP>. Con questi &egrave; possibile utilizzare delle opzioni finali, ovvero dei modificatori, che alterano le regole delle <A NAME="index16313"></A>espressioni regolari. La tabella <A HREF="a2249.html#anchor3803">191.6</A> mostra l'elenco dei modificatori pi&ugrave; comuni.</P>

<TABLE ID="anchor3803" BORDER="3">

<THEAD>
<TR><TD>Modificatore </TD><TD>Descrizione </TD></TR>
</THEAD>

<TBODY>
<TR><TD>i </TD><TD>Il confronto avviene ignorando la differenza tra maiuscole e minuscole. </TD></TR>
<TR><TD>m </TD><TD>Le stringhe vengono trattate come righe multiple (riguarda <SAMP>^</SAMP> e <SAMP>$</SAMP>). </TD></TR>
<TR><TD>s </TD><TD>Tratta le stringhe come una singola riga (riguarda <SAMP>.</SAMP>). </TD></TR>
<TR><TD>x </TD><TD>Permette l'inserzione di spazi e commenti che non vengono interpretati. </TD></TR>
</TBODY>
</TABLE>

<P><EM> Tabella <A HREF="a2249.html#anchor3803">191.6</A>. Elenco dei modificatori utilizzabili in generale in coda alle <A NAME="index16314"></A>espressioni regolari di <A NAME="index16315"></A>Perl. </EM></P>

<H3>191.2.2 &nbsp; <A NAME="title3109"></A><A NAME="anchor3804"></A>
 Metacaratteri </H3>

<P>In generale, i caratteri utilizzati in un'<A NAME="index16316"></A>espressione regolare, che non abbiano un significato speciale, corrispondono a loro stessi nella stringa di comparazione. Ci&ograve; &egrave; come dire che la comparazione seguente &egrave; valida.</P>

<PRE>'Ciao' =~ /Ciao/</PRE>

<P>I <STRONG><EM>metacaratteri</EM></STRONG> di un'<A NAME="index16317"></A>espressione regolare sono dei simboli che hanno un significato diverso rispetto ai caratteri utilizzati per rappresentarli. La tabella <A HREF="a2249.html#anchor3805">191.7</A> mostra l'elenco dei metacaratteri pi&ugrave; comuni.</P>

<TABLE ID="anchor3805" BORDER="3">

<THEAD>
<TR><TD>Metacarattere </TD><TD>Descrizione </TD></TR>
</THEAD>

<TBODY>
<TR><TD>\ </TD><TD>Protegge il carattere seguente da un'interpretazione diversa da quella letterale. </TD></TR>
<TR><TD>^ </TD><TD>Corrisponde all'inizio di una riga. </TD></TR>
<TR><TD>. </TD><TD>Corrisponde a un carattere qualunque. </TD></TR>
<TR><TD>$ </TD><TD>Corrisponde alla fine di una riga. </TD></TR>
<TR><TD>| </TD><TD>Indica due possibilit&agrave; alternative alla sua sinistra e alla sua destra. </TD></TR>
<TR><TD>( ) </TD><TD>Definiscono un raggruppamento. </TD></TR>
<TR><TD>[ ] </TD><TD>Definiscono una classe di caratteri. </TD></TR>
</TBODY>
</TABLE>

<P><EM> Tabella <A HREF="a2249.html#anchor3805">191.7</A>. Elenco dei metacaratteri standard utilizzati in <A NAME="index16318"></A>Perl. </EM></P>

<P>La barra obliqua inversa protegge il carattere successivo da un'interpretazione diversa da quella letterale, quando la sequenza <SAMP>\<VAR>x</VAR></SAMP> (<VAR>x</VAR> rappresenta qui un carattere qualunque) non rappresenta gi&agrave; un metacarattere. In pratica, se <SAMP>\<VAR>x</VAR></SAMP> non ha un significato particolare, rappresenta semplicemente <SAMP><VAR>x</VAR></SAMP> in modo letterale.</P>

<P>L'accento circonflesso (<SAMP>^</SAMP>) corrisponde generalmente all'inizio di una riga; nello stesso modo, il simbolo dollaro (<SAMP>$</SAMP>) rappresenta la fine di una riga. Questi metacaratteri rappresentano in pratica la stringa nulla di inizio e di fine di una riga. Se la stringa da analizzare &egrave; composta da pi&ugrave; righe terminate dal <A NAME="index16319"></A>codice di interruzione di riga, &egrave; possibile fare in modo che <SAMP>^</SAMP> e <SAMP>$</SAMP> corrispondano all'inizio e alla fine di queste righe virtuali utilizzando il modificatore <SAMP>m</SAMP>.</P>

<P>Il punto rappresenta un carattere singolo, con l'esclusione del <A NAME="index16320"></A>codice di interruzione di riga a meno che sia stato utilizzato il modificatore <SAMP>s</SAMP>.</P>

<P><A NAME="index16321"></A>Perl aggiunge a quelli standard una serie di metacaratteri rappresentati dalla tabella <A HREF="a2249.html#anchor3806">191.8</A>.</P>

<TABLE ID="anchor3806" BORDER="3">

<THEAD>
<TR><TD>Metacarattere </TD><TD>Corrispondenza </TD></TR>
</THEAD>

<TBODY>
<TR><TD>\w </TD><TD>Un carattere alfanumerico (lettere e numeri) compreso il simbolo di sottolineato. </TD></TR>
<TR><TD>\W </TD><TD>Un carattere non alfanumerico (l'opposto di <SAMP>\w</SAMP>). </TD></TR>
<TR><TD>\s </TD><TD>Uno spazio lineare (spazio o tabulazione). </TD></TR>
<TR><TD>\S </TD><TD>Qualunque carattere che non sia uno spazio lineare. </TD></TR>
<TR><TD>\d </TD><TD>Un carattere numerico. </TD></TR>
<TR><TD>\D </TD><TD>Un carattere non numerico. </TD></TR>
<TR><TD>\b </TD><TD>La stringa nulla prima o dopo una sequenza di caratteri corrispondenti a <SAMP>\w</SAMP>. </TD></TR>
<TR><TD>\B </TD><TD>La stringa nulla interna a una sequenza di caratteri corrispondenti a <SAMP>\w</SAMP>. </TD></TR>
<TR><TD>\A </TD><TD>L'inizio di una stringa. </TD></TR>
<TR><TD>\Z </TD><TD>La fine di una stringa (eventualmente prima di un <EM>newline</EM> finale). </TD></TR>
</TBODY>
</TABLE>

<P><EM> Tabella <A HREF="a2249.html#anchor3806">191.8</A>. Elenco dei metacaratteri speciali di <A NAME="index16322"></A>Perl. </EM></P>

<P>Inoltre, per complicare ulteriormente le cose, le <A NAME="index16323"></A>espressioni regolari di <A NAME="index16324"></A>Perl vengono trattate come se fossero racchiuse tra apici doppi, cio&egrave; vengono interpolate prima di essere valutate come <A NAME="index16325"></A>espressioni regolari. Questo significa che le variabili vengono espanse e vengono riconosciuti anche altri simboli che in pratica potrebbero essere considerati come dei metacaratteri aggiuntivi. Si tratta di <SAMP>\n</SAMP>, <SAMP>\t</SAMP> e altri come gi&agrave; indicato nella tabella <A HREF="a2249.html#anchor3789">191.1</A> all'inizio del capitolo.</P>

<H3>191.2.3 &nbsp; <A NAME="title3110"></A><A NAME="anchor3807"></A>
 Classi di caratteri </H3>

<P>Un modello racchiuso tra parentesi quadre rappresenta un solo carattere in base a quanto indicato nelle parentesi.</P>

<P>Una fila di caratteri racchiusa tra parentesi quadre corrisponde a un carattere qualunque tra quelli indicati; se all'inizio di questa fila c'&egrave; l'accento circonflesso, si ottiene una corrispondenza con un carattere qualunque diverso da quelli della fila. Per esempio, l'<A NAME="index16326"></A>espressione regolare <SAMP>[0123456789]</SAMP> corrisponde a una cifra numerica qualunque, mentre <SAMP>[^0123456789]</SAMP> corrisponde a un carattere qualunque purch&eacute; non sia una cifra numerica.</P>

<P>All'interno delle parentesi quadre, invece che indicare un insieme di caratteri, &egrave; possibile indicarne un intervallo mettendo il carattere iniziale e finale separati da un trattino (<SAMP>-</SAMP>). I caratteri che vengono rappresentati in questo modo dipendono dalla codifica che ne determina la sequenza. Per esempio, l'<A NAME="index16327"></A>espressione regolare <SAMP>[9-A]</SAMP> rappresenta un carattere qualsiasi tra: <SAMP>9</SAMP>, <SAMP>:</SAMP>, <SAMP>;</SAMP>, <SAMP>&lt;</SAMP>, <SAMP>=</SAMP>, <SAMP>&gt;</SAMP>, <SAMP>?</SAMP>, <SAMP>@</SAMP> e <SAMP>A</SAMP>, perch&eacute; cos&igrave; &egrave; la sequenza ASCII.</P>

<P>Questa definizione corrisponde in parte a quella di <SAMP>grep</SAMP> GNU, in particolare si deve tenere presente che all'interno delle parentesi quadre, <SAMP>\b</SAMP> corrisponde al carattere &lt;<EM>BS</EM>&gt;.</P>

<P>Un'altra diversit&agrave; rispetto alle <A NAME="index16328"></A>espressioni regolari di altri programmi sta nella mancanza di classi di caratteri espresse attraverso una denominazione. Ci&ograve; giustifica la presenza di metacaratteri che non ci sono normalmente. La tabella <A HREF="a2249.html#anchor3808">191.9</A> mostra l'abbinamento tra le classi delle <A NAME="index16329"></A>espressioni regolari comuni e i metacaratteri corrispondenti di <A NAME="index16330"></A>Perl.</P>

<TABLE ID="anchor3808" BORDER="3">

<THEAD>
<TR><TD><A NAME="index16333"></A>Perl </TD><TD><A NAME="index16334"></A>Espressioni regolari POSIX </TD></TR>
</THEAD>

<TBODY>
<TR><TD>\w </TD><TD>[[:alnum:]] </TD></TR>
<TR><TD>\W </TD><TD>[^[:alnum:]] </TD></TR>
<TR><TD>\s </TD><TD>[[:space:]] </TD></TR>
<TR><TD>\S </TD><TD>[^[:space:]] </TD></TR>
<TR><TD>\d </TD><TD>[[:digit:]] </TD></TR>
<TR><TD>\D </TD><TD>[^[:digit:]] </TD></TR>
</TBODY>
</TABLE>

<P><EM> Tabella <A HREF="a2249.html#anchor3808">191.9</A>. Comparazione tra alcuni metacaratteri di <A NAME="index16331"></A>Perl e le classi di caratteri equivalenti delle <A NAME="index16332"></A>espressioni regolari POSIX. </EM></P>

<H3>191.2.4 &nbsp; <A NAME="title3111"></A><A NAME="anchor3809"></A>
 Qualificatori -- operatori di ripetizione </H3>

<P>Attraverso altri simboli &egrave; possibile indicare la ripetizione di un carattere determinato o di un raggruppamento. La tabella <A HREF="a2249.html#anchor3810">191.10</A> mostra l'elenco di queste notazioni e il loro significato.</P>

<TABLE ID="anchor3810" BORDER="3">

<THEAD>
<TR><TD>Codifica </TD><TD>Corrispondenza. </TD></TR>
</THEAD>

<TBODY>
<TR><TD><VAR>x</VAR>* </TD><TD>Nessuna o pi&ugrave; volte <VAR>x</VAR>. Equivalente a <SAMP><VAR>x</VAR>{0,}</SAMP>. </TD></TR>
<TR><TD><VAR>x</VAR>? </TD><TD>Nessuna o al massimo una volta <VAR>x</VAR>. Equivalente a <SAMP><VAR>x</VAR>{0,1}</SAMP>. </TD></TR>
<TR><TD><VAR>x</VAR>+ </TD><TD>Una o pi&ugrave; volte <VAR>x</VAR>. Equivalente a <SAMP><VAR>x</VAR>{1,}</SAMP>. </TD></TR>
<TR><TD><VAR>x</VAR>{<VAR>n</VAR>} </TD><TD>Esattamente <VAR>n</VAR> volte <VAR>x</VAR>. </TD></TR>
<TR><TD><VAR>x</VAR>{<VAR>n</VAR>,} </TD><TD>Almeno <VAR>n</VAR> volte <VAR>x</VAR>. </TD></TR>
<TR><TD><VAR>x</VAR>{<VAR>n</VAR>,<VAR>m</VAR>} </TD><TD>Da <VAR>n</VAR> a <VAR>m</VAR> volte <VAR>x</VAR>. </TD></TR>
<TR><TD><VAR>x</VAR>*? </TD><TD>Equivale al minimo di <SAMP><VAR>x</VAR>*</SAMP>. </TD></TR>
<TR><TD><VAR>x</VAR>?? </TD><TD>Equivale al minimo di <SAMP><VAR>x</VAR>?</SAMP>. </TD></TR>
<TR><TD><VAR>x</VAR>+? </TD><TD>Equivale al minimo di <SAMP><VAR>x</VAR>+</SAMP>. </TD></TR>
<TR><TD><VAR>x</VAR>{<VAR>n</VAR>}? </TD><TD>Equivale al minimo di <SAMP><VAR>x</VAR>{<VAR>n</VAR>}</SAMP>, ovvero allo stesso <SAMP><VAR>x</VAR>{<VAR>n</VAR>}</SAMP>. </TD></TR>
<TR><TD><VAR>x</VAR>{<VAR>n</VAR>,}? </TD><TD>Equivale al minimo di <SAMP><VAR>x</VAR>{<VAR>n</VAR>,}</SAMP>. </TD></TR>
<TR><TD><VAR>x</VAR>{<VAR>n</VAR>,<VAR>m</VAR>}? </TD><TD>Equivale al minimo di <SAMP><VAR>x</VAR>{<VAR>n</VAR>,<VAR>m</VAR>}</SAMP>. </TD></TR>
</TBODY>
</TABLE>

<P><EM> Tabella <A HREF="a2249.html#anchor3810">191.10</A>. Operatori di ripetizione, o qualificatori, nelle <A NAME="index16335"></A>espressioni regolari di <A NAME="index16336"></A>Perl. </EM></P>

<P>Dalla tabella si pu&ograve; osservare la presenza di qualificatori insoliti che terminano con un punto interrogativo. Un modello espresso in forma di <A NAME="index16337"></A>espressione regolare pu&ograve; corrispondere a una stringa in diversi modi. Generalmente, la corrispondenza dei qualificatori avviene nel modo pi&ugrave; ampio possibile. Se &egrave; necessario che la corrispondenza avvenga nel modo pi&ugrave; ristretto possibile, occorre utilizzare i qualificatori che terminano con il punto interrogativo. Per esempio, di seguito si vedono alcune corrispondenze valide e le zone delle stringhe originali in cui i modelli combaciano.</P>

<PRE>"CIAO" =~ /\w+/
 ^--^

"Ciao, come stai?" =~ /\s/
      ^

"Ciao, come stai? Io sto bene." =~ /\s.*\s/
      ^-----------------^

"Ciao, come stai? Io sto bene." =~ /\s.*?\s/
      ^----^</PRE>

<H3>191.2.5 &nbsp; <A NAME="title3112"></A><A NAME="anchor3811"></A>
 Raggruppamenti </H3>

<P>Una o pi&ugrave; parti di un'<A NAME="index16338"></A>espressione regolare possono essere raggruppate attraverso l'uso delle parentesi tonde. Ci&ograve; permette di abbinare tali raggruppamenti ai qualificatori (gli operatori di ripetizione), oppure permette di estrarre ci&ograve; che corrisponde al segmento racchiuso tra parentesi, o di potervi fare riferimento. Per esempio, l'espressione <SAMP>\s(come\s)+.*\s</SAMP> &egrave; valida per tutte le stringhe seguenti.</P>

<PRE>"Ciao, come stai? Io sto bene."
"Ciao, come come stai? Io sto bene."
"Ciao, come come come stai? Io sto bene."
...</PRE>

<P>All'interno della stessa <A NAME="index16339"></A>espressione regolare &egrave; possibile fare riferimento a una corrispondenza parziale contenuta in un raggruppamento. Per farlo si utilizza il metacarattere <SAMP>\<VAR>n</VAR></SAMP>, dove <VAR>n</VAR> &egrave; una sola cifra numerica. In pratica, <SAMP>\1</SAMP> corrisponde al primo raggruppamento, <SAMP>\2</SAMP> corrisponde al secondo, e cos&igrave; di seguito, fino al nono.</P>

<P>Per esempio, <SAMP>(0|0x0)\d*\s\1\d*</SAMP> &egrave; valida per <SAMP>0x0123&nbsp;0x0456</SAMP>, ma non per <SAMP>0x0123&nbsp;0456</SAMP>. Infatti, si fa riferimento alla corrispondenza, non al modello che potrebbe essere ripetuto agevolmente.</P>

<P><A NAME="index16340"></A>Perl permette di utilizzare queste corrispondenze anche al di fuori delle <A NAME="index16341"></A>espressioni regolari. Per questo per&ograve; non si pu&ograve; pi&ugrave; utilizzare la notazione <SAMP>\<VAR>n</VAR></SAMP>, ma occorre invece <SAMP>$<VAR>n</VAR></SAMP>. In pratica si tratta di variabili predefinite che vengono generate per l'occasione. Per esempio,</P>

<PRE>s/^(\w+)\s+(\w+)/$2 $1/</PRE>

<P>inverte le prime due parole ed elimina gli spazi superflui tra le due. Un altro esempio interessante &egrave; il seguente, in cui si estrae la data da una stringa, per gestirla all'interno del programma.</P>

<PRE>if ($miadata =~ m|Data:\s+(\d\d)/(\d\d)/(\d{2,4})|)
  {
    $giorno = $1;
    $mese = $2;
    $anno = $3;
  }</PRE>

<P>Come si pu&ograve; vedere, i delimitatori dell'<A NAME="index16342"></A>espressione regolare sono stati sostituiti con le barre verticali, in modo da poter utilizzare le barre oblique per l'espressione stessa senza troppi problemi.</P>
Appunti di informatica libera 2001.08.18  --- <EM>Copyright &copy; 2000-2001 Daniele Giacomini -- &nbsp;daniele&nbsp;@&nbsp;swlibero.org</EM></DIV>
<HR>
<P>Dovrebbe essere possibile fare riferimento a questa pagina anche con il nome  <A HREF="perl_gestione_delle_stringhe.html">perl_gestione_delle_stringhe.html</A></P>
<P>
<A HREF="a2250.html">[successivo]</A>
<A HREF="a2248.html">[precedente]</A>
<A HREF="a2.html">[inizio]</A>
<A HREF="a2506.html">[fine]</A>
<A HREF="a21.html">[indice generale]</A>
<A HREF="a26.html">[violazione GPL]</A>
<A HREF="a2504.html">[licenze]</A>
<A HREF="a2505.html">[indice analitico]</A>
</P>
</BODY>
</HTML>