Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 13-05-2010, 22:53   #1
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
[Java] convertire String --> String[]

Ho usato PDF Box per convertire da PDF a String.
La String in questione è molto lunga e va a capo automatico.
Come faccio a convertirla in un String[]? di solito uso split(), però che ci metto come parametro? per la riga nuova esiste un parametro?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 13-05-2010, 23:09   #2
deadlyomen17
Senior Member
 
L'Avatar di deadlyomen17
 
Iscritto dal: Sep 2004
Città: Cosenza
Messaggi: 2971
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
Ho usato PDF Box per convertire da PDF a String.
La String in questione è molto lunga e va a capo automatico.
Come faccio a convertirla in un String[]? di solito uso split(), però che ci metto come parametro? per la riga nuova esiste un parametro?
va benissimo split, come parametro basta passargli il carattere di fine linea \n

es:
Codice PHP:
String text "prima riga\nseconda riga\nterza riga";
String[] strings text.split("\n");
for( 
int i 0strings.lengthi++ ) {
    
System.out.println"string[" "] = " strings[i] );

output:
Codice:
string[0] = prima riga
string[1] = seconda riga
string[2] = terza rigaa
deadlyomen17 è offline   Rispondi citando il messaggio o parte di esso
Old 14-05-2010, 18:56   #3
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
...sto riscrivendo gran parte del programma. Non ho ancora provato ma sono sicuro che funzioni. In effetti sapevo del "\n", ma non mi ricordavo.
Ti faccio sapere;
grazie.
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 16-05-2010, 23:39   #4
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Come presumevo, funziona. Ora il problema è un altro. Dopo aver fatto il lavoro descritto sopra, con il metodo println() a video mi ritrovo parte dell'array:

Codice:
[1] V. R. Basili, L. C. Briand, and W. L. Melo. A validation of
Trans. Softw. Eng., 22(10):751–761, 1996.
Usando poi JDomWriter per creare un Xml, lui mi scrive:

Codice:
[1] V. R. Basili, L. C. Briand, and W. L. Melo. A validation of
Trans. Softw. Eng., 22(10):751–761, 1996.
QUesto 
 presumo sia l'interruzione di linea. C'è modo di eliminarlo?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 00:31   #5
deadlyomen17
Senior Member
 
L'Avatar di deadlyomen17
 
Iscritto dal: Sep 2004
Città: Cosenza
Messaggi: 2971
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
Come presumevo, funziona. Ora il problema è un altro. Dopo aver fatto il lavoro descritto sopra, con il metodo println() a video mi ritrovo parte dell'array:

Codice:
[1] V. R. Basili, L. C. Briand, and W. L. Melo. A validation of
Trans. Softw. Eng., 22(10):751–761, 1996.
Usando poi JDomWriter per creare un Xml, lui mi scrive:

Codice:
[1] V. R. Basili, L. C. Briand, and W. L. Melo. A validation of
Trans. Softw. Eng., 22(10):751–761, 1996.
QUesto 
 presumo sia l'interruzione di linea. C'è modo di eliminarlo?

 è il carriage return

non ho ben capito cosa vuoi fare e cosa stai facendo.

spiega meglio e cercherò di aiutarti
deadlyomen17 è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 06:57   #6
Kenger
Member
 
Iscritto dal: Aug 2005
Messaggi: 168
Immagino che il problema sia che sotto windows il ritorno a capo è \r\n mentre sotto linux è solo \n (o il contrario, non ricordo mai).
Io fossi in te farei un string.replace("\r", ""); e poi lo split.
Kenger è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 11:02   #7
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da deadlyomen17 Guarda i messaggi

 è il carriage return

non ho ben capito cosa vuoi fare e cosa stai facendo.

spiega meglio e cercherò di aiutarti
OK,
ho parsato un PDF con PdfBox ed ho così ottenuto una Stringa con dentro (quasi) tutto il PDF. Essendo interessato alle referenze a fondo pagina, ho dovuto scrivere del codice che andasse a prendere solo determinate righe. Avendo una stringa unica, mi era difficile trovare ed estrarre le referenze, perciò ho prima fatto lo split come spiegato nei primi post per avere un array di stringhe e poi sono andato in cerca delle referenze in base all'inizio di ognuna stringa.
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 11:26   #8
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da Kenger Guarda i messaggi
Immagino che il problema sia che sotto windows il ritorno a capo è \r\n mentre sotto linux è solo \n (o il contrario, non ricordo mai).
Io fossi in te farei un string.replace("\r", ""); e poi lo split.
...dato che usavo lo "\n" per fare lo split...se faccio prima il replaceAll(), poi come faccio a fare lo split?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 14:44   #9
Kenger
Member
 
Iscritto dal: Aug 2005
Messaggi: 168
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
...dato che usavo lo "\n" per fare lo split...se faccio prima il replaceAll(), poi come faccio a fare lo split?
Il replace lo fai sul \r non sul \n
Kenger è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 14:52   #10
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da Kenger Guarda i messaggi
Il replace lo fai sul \r non sul \n
Funziona, però non ho capito perchè. Puoi spiegarmi con precisione?
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 14:53   #11
deadlyomen17
Senior Member
 
L'Avatar di deadlyomen17
 
Iscritto dal: Sep 2004
Città: Cosenza
Messaggi: 2971
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
OK,
ho parsato un PDF con PdfBox ed ho così ottenuto una Stringa con dentro (quasi) tutto il PDF. Essendo interessato alle referenze a fondo pagina, ho dovuto scrivere del codice che andasse a prendere solo determinate righe. Avendo una stringa unica, mi era difficile trovare ed estrarre le referenze, perciò ho prima fatto lo split come spiegato nei primi post per avere un array di stringhe e poi sono andato in cerca delle referenze in base all'inizio di ognuna stringa.
fin qui tutto chiaro.
Dopo ciò il tuo scopo è creare un XML in cui mettere soltanto le referenze?

Che struttura deve avere questo XML?

Per arrivare ad avere, a partire da un'unica stringa, soltanto l'ultima parte con le referenze, potresti usare un altro metodo:

ottieni l'indice della prima referenza tramite il metodo
Codice:
int java.lang.String.indexOf(String  str)
passandogli una stringa che identifica la prima referenza (nell'esempio che hai postato, puoi passargli "[1]")

salvi la sottostringa che va dall'indice appena trovato fino alla fine della stringa, tramite il metodo
Codice:
String  java.lang.String.substring(int beginIndex, int endIndex)
splitti questa stringa usando un parametro che identifica la fine di una referenza e l'inizio di un'altra (se per esempio dopo ogni referenza di sono due endline, come avviene di solito, puoi usare \n\n (o forse nel tuo caso \n\r\n\r) come parametro).

in questo modo ottieni un array di stringhe in cui ogni stringa è una referenza intera (con eventuali endline singoli, come nel tuo esempio)

a questo punto puoi rimuovere gli endline all'interno di ogni referenza usando il metodo:
Codice:
String  java.lang.String.replaceAll(String  regex, String  replacement)
a cui passi come regex "\n\r" e come replacement uno spazio " "

il risultato finale sarà un array in cui ogni stringa è esattamente una referenza, rappresentata come unica linea, che puoi inserire in un XML senza problemi.
deadlyomen17 è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 14:56   #12
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da deadlyomen17 Guarda i messaggi
fin qui tutto chiaro.
Dopo ciò il tuo scopo è creare un XML in cui mettere soltanto le referenze?

Che struttura deve avere questo XML?

Per arrivare ad avere, a partire da un'unica stringa, soltanto l'ultima parte con le referenze, potresti usare un altro metodo:

ottieni l'indice della prima referenza tramite il metodo
Codice:
int java.lang.String.indexOf(String  str)
passandogli una stringa che identifica la prima referenza (nell'esempio che hai postato, puoi passargli "[1]")

salvi la sottostringa che va dall'indice appena trovato fino alla fine della stringa, tramite il metodo
Codice:
String  java.lang.String.substring(int beginIndex, int endIndex)
splitti questa stringa usando un parametro che identifica la fine di una referenza e l'inizio di un'altra (se per esempio dopo ogni referenza di sono due endline, come avviene di solito, puoi usare \n\n (o forse nel tuo caso \n\r\n\r) come parametro).

in questo modo ottieni un array di stringhe in cui ogni stringa è una referenza intera (con eventuali endline singoli, come nel tuo esempio)

a questo punto puoi rimuovere gli endline all'interno di ogni referenza usando il metodo:
Codice:
String  java.lang.String.replaceAll(String  regex, String  replacement)
a cui passi come regex "\n\r" e come replacement uno spazio " "

il risultato finale sarà un array in cui ogni stringa è esattamente una referenza, rappresentata come unica linea, che puoi inserire in un XML senza problemi.
Difatti il problema era proprio il togliere quel 
 Facendo come dice Kenger ho risolto.
Grazie ad entrambi.
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 14:59   #13
Gold
Member
 
L'Avatar di Gold
 
Iscritto dal: Oct 2002
Messaggi: 133
Non sarebbe meglio usare System.getProperty("line.separator") invece di \n o \r\n??
Gold è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 14:59   #14
deadlyomen17
Senior Member
 
L'Avatar di deadlyomen17
 
Iscritto dal: Sep 2004
Città: Cosenza
Messaggi: 2971
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
Funziona, però non ho capito perchè. Puoi spiegarmi con precisione?
i sistemi Windows utilizzano CR+LF per rappresentare il "a capo" (newline)
mentre i sistemi unix e unix-like usano LF
apple utilizza solo CR

fonte: http://it.wikipedia.org/wiki/Newline

resta comunque il consiglio di prima.
deadlyomen17 è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 15:02   #15
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da Gold Guarda i messaggi
Non sarebbe meglio usare System.getProperty("line.separator") invece di \n o \r\n??
Immagino che dipenda su quale SO usi il programma. Ora facendo come descritto sopra su Win funziona, però potrebbe essere che su MAC o Linux non funziona. Come mi consigli di fare?

Il codice attuale:
Codice:
private void parsePdf() throws IOException {
		PDFTextStripper stripper = new PDFTextStripper();
		String text = stripper.getText(this.pdfBoxDocument);
		text = text.replace("\r", "");
		this.parsedText = text.split("\n");
	}
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 15:05   #16
deadlyomen17
Senior Member
 
L'Avatar di deadlyomen17
 
Iscritto dal: Sep 2004
Città: Cosenza
Messaggi: 2971
Quote:
Originariamente inviato da Gold Guarda i messaggi
Non sarebbe meglio usare System.getProperty("line.separator") invece di \n o \r\n??
Assolutamente corretto. Non ci avevo pensato.

Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
Immagino che dipenda su quale SO usi il programma. Ora facendo come descritto sopra su Win funziona, però potrebbe essere che su MAC o Linux non funziona. Come mi consigli di fare?
System.getProperty("line.separator") ti ritorna la stringa che nel tuo sistema rappresenta newline.

quindi \n per sistemi *nix, \r per sistemi Mac, \n\r per sistemi NT
deadlyomen17 è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 15:07   #17
deadlyomen17
Senior Member
 
L'Avatar di deadlyomen17
 
Iscritto dal: Sep 2004
Città: Cosenza
Messaggi: 2971
Quote:
Originariamente inviato da Emaborsa Guarda i messaggi
Il codice attuale:
Codice:
private void parsePdf() throws IOException {
		PDFTextStripper stripper = new PDFTextStripper();
		String text = stripper.getText(this.pdfBoxDocument);
		text = text.replace("\r", "");
		this.parsedText = text.split("\n");
	}
a questo punto perchè non fare direttamente
Codice:
this.parsedText = text.split("\n\r");
o ancora megliO:
Codice:
this.parsedText = text.split(System.getProperty("line.separator"));
deadlyomen17 è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 15:08   #18
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
...o così, per averlo più leggibile:
Codice:
private void parsePdf() throws IOException {
		PDFTextStripper stripper = new PDFTextStripper();
		String text = stripper.getText(this.pdfBoxDocument);
		String lineSeparator = System.getProperty("line.separator"); 
		this.parsedText = text.split(lineSeparator);
	}
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 15:21   #19
Kenger
Member
 
Iscritto dal: Aug 2005
Messaggi: 168
Perfetto, sono niubbissimo in java e non sapevo si potesse fare così. Grazie.
Kenger è offline   Rispondi citando il messaggio o parte di esso
Old 17-05-2010, 15:23   #20
Emaborsa
Senior Member
 
L'Avatar di Emaborsa
 
Iscritto dal: Sep 2004
Città: Bolzano
Messaggi: 2163
Quote:
Originariamente inviato da Kenger Guarda i messaggi
Perfetto, sono niubbissimo in java e non sapevo si potesse fare così. Grazie.
Io più che altro non sapevo di questo lineseparator...
__________________
Vendo...nulla.
Cerco...la felicità
.
Emaborsa è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Roscosmos ha posticipato (ancora) il lan...
Isar Aerospace si prepara al secondo lan...
Tory Bruno è entrato in Blue Orig...
Fujifilm lancia la cartuccia per archivi...
Dreame H15 Mix: la soluzione 7-in-1 per ...
AirPods Pro 3 in forte sconto su Amazon:...
36 offerte Amazon, molte appena partite:...
2 caricatori multipli eccezionali: da 28...
OLED e 360 Hz a un prezzo senza preceden...
Roborock Q10 S5+ a un prezzo molto conve...
Upgrade PC a prezzo ridotto: le migliori...
Sono i 6 smartphone migliori su Amazon: ...
Google Pixel 9a a 361€, mai così ...
Super sconti sugli spazzolini Oral-B, an...
Aspira a 6000Pa, lava bene, costa 139€: ...
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: 19:52.


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