Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
ASUS Expertbook PM3: il notebook robusto per le aziende
ASUS Expertbook PM3: il notebook robusto per le aziende
Pensato per le necessità del pubblico d'azienda, ASUS Expertbook PM3 abbina uno chassis particolrmente robusto ad un pannello da 16 pollici di diagonale che avantaggia la produttività personale. Sotto la scocca troviamo un processore AMD Ryzen AI 7 350, che grazie alla certificazione Copilot+ PC permette di sfruttare al meglio l'accelerazione degli ambiti di intelligenza artificiale
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-01-2007, 17:46   #1
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
[javascript]Regular expression

Non riesco a capire come usare bene questo oggetto.
Io vorrei cercare in un testo una frase così composta:

parola_1 parola_2 gruppo_numerico

ad esempio:
pippo pluto 10.103

però gli spazi potrebbero essere anche più di uno e la parola_2 potrebbe anche non esserci, ma vorrei essere sicuro che il gruppo_numerico sia dopo la parola_1, come potrei fare?

Io ho provato così:
Codice:
var str="ciao mondo 11100";
var reg=new RegExp("(ciao)\s+(mondo)*\s+(11100)","i");
alert(reg.test(str));
Ma mi da sempre false, dove sbaglio?
Da quel che ho capito \s sono gli spazi, + significa una o piò occorrenze e * significa zero o più occorrenze, giusto?
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 14-01-2007, 18:00   #2
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
funziona con:
ciao\s*[A-z]*\s*11100
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 14-01-2007, 20:52   #3
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Prova questo:
Codice:
var str = "ciao mondo 11100";

var reg = new RegExp ("^(\\w+)\\s+((\\w+)\\s+)?(\\d+\\.?\\d+)$", "i");

if (reg.test (str))
{
    var arr = reg.exec (str);

    alert ("parte1 = [" + arr[1] + "]\r\n" +
           "parte2 = [" + arr[3] + "]\r\n" +
           "parte3 = [" + arr[4] + "]\r\n");
}
Prova a togliere "mondo " e vedrai che arr[3] vale 'undefined'
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2007, 21:27   #4
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
ho ancora qualche problemino, mettiamo che abbia una stringa così composta:

_blabla bl 123456 blaa_ciao mondo!_bla bla pappapero_

come faccio ad eliminare la parte di testo compresa fra i caratteri '_' senza che sappia com'è composta?

ho provato un str.replace(/_.+_/i,"") ma mi cancella tutta la stringa!
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2007, 22:37   #5
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da MEMon
ho ancora qualche problemino, mettiamo che abbia una stringa così composta:

_blabla bl 123456 blaa_ciao mondo!_bla bla pappapero_

come faccio ad eliminare la parte di testo compresa fra i caratteri '_' senza che sappia com'è composta?

ho provato un str.replace(/_.+_/i,"") ma mi cancella tutta la stringa!
Ci siamo quasi ... ma c'è una piccola questione che non hai considerato (o probabilmente non conosci). L'espressione X+ è un quantificatore definito "greedy" (=avido, ingordo) perché cerca di catturare il massimo numero di caratteri possibili. Quindi, con la stringa di input sopra, cattura tutto ciò che c'è tra il primo _ e l'ultimo _ (quello dopo pappapero) e non solo fino al _ dopo blaa (come si vorrebbe).
La soluzione è usare un quantificatore non greedy.

str.replace(/_.+?_/gi,"")

Il '?' rende il quantificatore non greedy, adesso cerca di catturare il minor numero di caratteri. Il flag 'g' serve per continuare nel replace, così non si ferma al primo match.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2007, 22:39   #6
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Grazie mille chiarissimo!
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 23-01-2007, 22:57   #7
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Certo che è potente come cosa, con sti affari si riesce a fare quasi ogni tipo lavorazione sulle stringhe
ed è anche abbastanza veloce.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2007, 17:26   #8
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
se devo cercare una parola all'interno di una stringa che contiene molte righe, e ne devo ricavare la sola riga che contiene la parola come faccio?
ad esempio ho:

_eijfjehbjcfrhguivrbjkvbjrkbcvrvucrubr CIAO rejfbeurbfierbfcirbgviyvryvrbhcr_
_urefgurigfurgfuirgfvurguivgruvgyrgvirgvuirgvuirurgvuirgvuirguivgruivgruvgruivuir_
_roivhruivgurrkjfrlihvrkgvurgvuigrvuigrviugruvgruvgurgvuigruivgruivgr_

e devo ricavare solo la prima riga perchè contiene la parola CIAO.

Tutte le righe iniziano e finiscono con il medesimo carattere.

ho provato con str.match(/_.+?CIAO.+?_/gi);
ma mi da anche le altre righe...
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2007, 18:15   #9
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da MEMon
ho provato con str.match(/_.+?CIAO.+?_/gi);
A me sembra corretto.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2007, 18:20   #10
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
bho a me nn funziona cmq ho risolto in un altro modo.
Ora mi serve l'ultimo ritocchino, presente i caratteri > < & " ecc ecc, che per scriverli in codice html vanno inseriti con &gt; &lt; &quot; &amp;
ecco, se io ho una stringa con quei caratteri, c'è un modo per rimpiazzarli con il rispettivo codice asci tutti in una volta?

es.
var str=ciao &quot;pippo&quot; 10&gt;5

avere ciao"pippo" 10>5

altrimenti dovrei fare tanti replace uno per ogni caso.
Sto lavorando in javascript sempre
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2007, 18:31   #11
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
anche xkè i caratteri speciali sn questi:
Codice:
¢ = &cent;
£ = &pound;
¤ = &curren;
¥ = &yen;
¦ = &brvbar;
§ = &sect;
¨ = &uml;
© = &copy;
ª = &ordf;
« = &laquo;
¬ = &not;
® = &reg;
¯ = &macr;
° = &deg;
± = &plusmn;
² = &sup2;
³ = &sup3;
´ = &acute;
µ = &micro;
¶ = &para;
· = &middot;
¸ = &cedil;
¹ = &sup1;
º = &ordm;
» = &raquo;
¼ = &frac14;
½ = &frac12;
¾ = &frac34;
¿ = &iquest;

À = &Agrave;
Á = &Aacute;
 = &Acirc;
à = &Atilde;
Ä = &Auml;
Å = &Aring;
Æ = &AElig;
Ç = &Ccedil;
È = &Egrave;
É = &Eacute;
Ê = &Ecirc;
Ë = &Euml;
Ì = &Igrave;
Í = &Iacute;
Î = &Icirc;
Ï = &Iuml;
Ð = &ETH;
Ñ = &Ntilde;
Ò = &Ograve;
Ó = &Oacute;
Ô = &Ocirc;
Õ = &Otilde;
Ö = &Ouml;
× = &times;
Ø = &Oslash;
Ù = &Ugrave;
Ú = &Uacute;
Û = &Ucirc;
Ü = &Uuml;
Ý = &Yacute;
Þ = &THORN;
ß = &szlig;

à = &agrave;
á = &aacute;
â = &acirc;
ã = &atilde;
ä = &auml;
å = &aring;
æ = &aelig;
ç = &ccedil;
è = &egrave;
é = &eacute;
ê = &ecirc;
ë = &euml;
ì = &igrave;
í = &iacute;
î = &icirc;
ï = &iuml;
ð = &eth;
ñ = &ntilde;
ò = &ograve;
ó = &oacute;
ô = &ocirc;
õ = &otilde;
ö = &ouml;
÷ = &divide;
ø = &oslash;
ù = &ugrave;
ú = &uacute;
û = &ucirc;
ü = &uuml;
ý = &yacute;
þ = &thorn;
ÿ = &yuml;

" = &quot;
& = &amp;
< = &lt;
> = &gt;
€ = &euro;
ˆ = &circ;
˜ = &tilde;
… = &hellip;
™ = &trade;
E se devo fare i casi per tutti non finisco più!!!
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 24-01-2007, 22:51   #12
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da MEMon
altrimenti dovrei fare tanti replace uno per ogni caso.
Esatto ... non ci sono funzioni "standard" per fare questo in Javascript. Fai tanti replace per ogni entità, almeno per le 5 entità "standard".
Quote:
Originariamente inviato da MEMon
anche xkè i caratteri speciali
Per quale motivo devi ottenere le entità per tutti i caratteri speciali?? Se nella stringa i caratteri speciali sono codificati con lo stesso charset dichiarato in testa al html, allora puoi "buttare" fuori direttamente il carattere.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2007, 19:04   #13
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Ho ancora dei problemi uff...
Ho del testo con tante righe, tutte le righe iniziano con lo stesso gruppo di caratteri e finiscono tutte con lo stesso gruppo di caratteri, ma al loro interno possono avere qualsiasi carattere, anche dei tab, dei return ecc ecc.

Es

abc bla blakjhndefhnerhcf xejcengchr crjivhc iur vrcv rcvoirhciur zzz
abc bla blakjhndefhnerhcf xejcengchr crjivhc iur vrcv rcvoirhciur zzz
abc bla blakjhndefhnerhcf xe KEY hr crjivhc iur vrcv rcvoirhciur zzz
abc bla blakjhndefhnerhcf xejcengchr crjivhc iur vrcv rcvoirhciur zzz

a me interessa avere tutta la riga che contiene la parola KEY.

se faccio un
abc.+?KEY.+?zzz non funziona perchè come ho già detto possono esserci anche dei \n \r che il . non comprende... e in più non so per quale motivo ma mi prende dal primo abc che incontra fino a KEY
Secondo me per questo genere di cose c'è un qualcosa di più avanzato.
Non c'è qualcosa per dirgli, guarda il più vicino possibile alla parola KEY?
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2007, 19:22   #14
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da MEMon
se faccio un
abc.+?KEY.+?zzz non funziona perchè come ho già detto possono esserci anche dei \n \r che il . non comprende... e in più non so per quale motivo ma mi prende dal primo abc che incontra fino a KEY
Secondo me per questo genere di cose c'è un qualcosa di più avanzato.
Non c'è qualcosa per dirgli, guarda il più vicino possibile alla parola KEY?
Ecco:

abc(?:.|[\r\n])+?KEY(?:.|[\r\n])+?zzz

Il significato di (?:.|[\r\n]) è semplice: è un raggruppamento (senza capturing) di qualunque carattere oppure \r o \n
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2007, 19:54   #15
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Ma mi prende tutte le righe così xò

Ultima modifica di MEMon : 27-01-2007 alle 20:01.
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2007, 23:28   #16
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da MEMon
Ma mi prende tutte le righe così xò
Già, è vero! Diciamo che prende più righe del necessario. Ho fatto adesso la prova con questo testo:

abc 11 xxx 111 zzz
abc 22 KEY 222 zzz
abc 33 yyy 333 zzz
abc 44 KEY 444 zzz

con il flag 'g' darebbe un array di 2 elementi, il primo prende le prime due righe e il secondo le altre due. Dopotutto, se accetti di poter avere in mezzo un newline, come farebbe a capire che vuoi solo:

abc 22 KEY 222 zzz

e non

abc 11 xxx 111 zzz
abc 22 KEY 222 zzz

?

Bisognerebbe ragionarci un po' su .... non saprei ....
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 27-01-2007, 23:37   #17
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Quindi se ho:
Codice:
abc jrfbekj
rnfnrfnrfn rfcnr rornfr zzz

abc rkfnrjfnrjnf lrfkrf KEY rkfnrl
rnfkrnfr zzz
Non posso isolare il gruppo abc-zzz che ha in mezzo KEY?
MEMon è offline   Rispondi citando il messaggio o parte di esso
Old 28-01-2007, 11:44   #18
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Ci sono riuscito! Ecco l'espressione:

abc((.|\r|\n)(?!abc))+?KEY(.|\r|\n)+?zzz

da usare con il flag 'g' e da eseguire con il metodo match() di String.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 28-01-2007, 11:59   #19
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
si c'ero arrivato anche io stamattina, xò mi sn accorto che il gruppo zzz a volte manca quindi il fine stringa diventa un abc.
Ho provato questo:

abc((.|\n)(?!abc))+?KEY(.|\n)+?(zzz|abc) ma così torna a prendermi tutto...

Per questo motivo sono passato allo split, in questo modo:

var row=str.split("KEY");
var s1=row[0].split("abc")[1];
var s2=row[1].split(/abc|zzz/)[0];
var tot=s1+"KEY"+s2;

ecco così funziona, ma a volte la parola KEY è presente più volte nella stessa riga, quindi ho fatto:

var arr=str.split("KEY");
var s1=arr.splice(0,1)[0].split("abc")[1];
var s2=arr.join("KEY").split(/abc|zzz/)[0];
var tot=s1+"KEY"+s2;

e così ho risolto ma ora è sensibilmente più lento l'algoritmo.
MEMon è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Recensione OnePlus 15: potenza da vendere e batteria enorme dentro un nuovo design   Recensione OnePlus 15: potenza da vendere e batt...
BMW iX3: la Neue Klass supera i 1.000 km...
LinusTechTips pensa che Steam Machine do...
Black Friday Amazon: avviatori auto e ac...
Warner e Udio depongono le armi: l'IA di...
Snapdragon 8 Gen 5: il nuovo processore ...
Black Friday OPPO: prezzi a picco su sma...
Arriva il nuovo Amazon Haul per il Black...
Mafia: Terra Madre: arriva il Free Ride ...
L'UE approva 70 progetti (anche in Itali...
Nuovo Cayenne Electric: è la Pors...
Adobe acquisisce Semrush per 1,9 miliard...
Black Friday Ecovacs: i migliori robot a...
Prime Video lancia i Video Recaps: la fu...
Tutti i prodotti FRITZ!Box scendono di p...
Copilot Actions può installare ma...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 13:01.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v