• Post Reply Bookmark Topic Watch Topic
  • New Topic
programming forums Java Mobile Certification Databases Caching Books Engineering Micro Controllers OS Languages Paradigms IDEs Build Tools Frameworks Application Servers Open Source This Site Careers Other Pie Elite all forums
this forum made possible by our volunteer staff, including ...
Marshals:
  • Campbell Ritchie
  • Jeanne Boyarsky
  • Ron McLeod
  • Paul Clapham
  • Liutauras Vilda
Sheriffs:
  • paul wheaton
  • Rob Spoor
  • Devaka Cooray
Saloon Keepers:
  • Stephan van Hulst
  • Tim Holloway
  • Carey Brown
  • Frits Walraven
  • Tim Moores
Bartenders:
  • Mikalai Zaikin

CSV Format not Working

 
Ranch Hand
Posts: 74
1
  • Number of slices to send:
    Optional 'thank-you' note:
The below program work flawlessly in a recently completed program. However, when I did a new program, using the same CSV code, it doesn't output the database fields to a csv file. I placed a System print just below the data string declaration and do get a partial of the first record --but not the complete record. Not sure what I'm doing different.

In my previous program, I used the comma deliminator by stating the CSVFormat to "CSVFormat format = CSVFormat.RFC4180.withRecordSeparator(",")". In this new program, the "withRecordSeparator" Netbeans deprecates it. Not sure how to resolve this since the format parameter has changed. I use Zulu OpenJDK 17 within Netbeans 17 in a Windows 10 OS.

 
Saloon Keeper
Posts: 10796
86
  • Number of slices to send:
    Optional 'thank-you' note:
What do you get?
On line 53 you commented out the print and I don't see the system print you mentioned.
 
Carey Brown
Saloon Keeper
Posts: 10796
86
  • Number of slices to send:
    Optional 'thank-you' note:
Use the auto-formatting capability of Netbeans. Example:
 
Carey Brown
Saloon Keeper
Posts: 10796
86
 
Marshal
Posts: 4533
572
  • 1
  • Number of slices to send:
    Optional 'thank-you' note:
You should either handle the database exceptions or let them bubble up.  Hiding them is going to bring you grief, in both development and production.
 
Ron McLeod
Marshal
Posts: 4533
572
  • Number of slices to send:
    Optional 'thank-you' note:

Bill Melendez wrote:I used the comma deliminator by stating the CSVFormat to "CSVFormat format = CSVFormat.RFC4180.withRecordSeparator(",")". In this new program, the "withRecordSeparator" Netbeans deprecates it.


Assuming that you are using Apache Commons CSV, the current documentation indicates that you should be using a CSVFormat.Builder and setting the delimiter with the setRecordSeparator method.
 
Ranch Hand
Posts: 32
2
  • 1
  • Number of slices to send:
    Optional 'thank-you' note:
This works for me



I used here sqlite mydb.db with mytable:

sqlite> .schema mytable
CREATE TABLE mytable(c1 TEXT,c2 TEXT,c3 REAL);
sqlite> select * from mytable;
aaa|my text|1.2
bbb|my text 2|0.99
ccc|my text 3|1.33


And the output mycsv.csv file is

c1,c2,c3
aaa,my text,1.2,
bbb,my text 2,0.99,
ccc,my text 3,1.33,

 
Bill Melendez
Ranch Hand
Posts: 74
1
  • Number of slices to send:
    Optional 'thank-you' note:
Grzegorz: Thanks. I redid the whole thing to the below code which works great for me. I do appreciate your post though. The key is to move away from having a "main" that activates the CSV export. Instead, I prefer to use it as a "method" that can work when called by a jbutton within a main program.  

 
Bill Melendez
Ranch Hand
Posts: 74
1
  • Number of slices to send:
    Optional 'thank-you' note:
Grzegorz:  here's the main screen that applies the CSV Save output. It is a Phone Logging for customer support calls and actions taken. I cleared the entry form since the information is not needed for displaying this screen to this post. Otherwise, the right side is a JTABLE with the database records displayed. Clicking on a row will populate the entry form.
PhoneLog-Main-Screen.png
 
Carey Brown
Saloon Keeper
Posts: 10796
86
  • Number of slices to send:
    Optional 'thank-you' note:
Indent cleanup.
Remove outer try, unnecessary.
Declare rowData on line 29.
Comment out unused HEADER String.
Marked probable problem on line 27.
Removed throws because you don't.
Catching  all non-IOExceptions is a bad idea. at least log them.
 
Saloon Keeper
Posts: 27865
196
  • Number of slices to send:
    Optional 'thank-you' note:

Ron McLeod wrote:You should either handle the database exceptions or let them bubble up.  Hiding them is going to bring you grief, in both development and production.

Hiding them would earn you a good hiding if I ever inherited that code.  
 
Bill Melendez
Ranch Hand
Posts: 74
1
  • Number of slices to send:
    Optional 'thank-you' note:
@Carey: Thank you so much for your insight and comments. I will apply what you suggested.
 
Marshal
Posts: 28262
95
  • Number of slices to send:
    Optional 'thank-you' note:

Ron McLeod wrote:You should either handle the database exceptions or let them bubble up.  Hiding them is going to bring you grief, in both development and production.


A better way to fix this particular instance of exception hiding:

Commonly called "multicatch", released in Java 7.
 
With a little knowledge, a cast iron skillet is non-stick and lasts a lifetime.
reply
    Bookmark Topic Watch Topic
  • New Topic
vceplus-200-125    | boson-200-125    | training-cissp    | actualtests-cissp    | techexams-cissp    | gratisexams-300-075    | pearsonitcertification-210-260    | examsboost-210-260    | examsforall-210-260    | dumps4free-210-260    | reddit-210-260    | cisexams-352-001    | itexamfox-352-001    | passguaranteed-352-001    | passeasily-352-001    | freeccnastudyguide-200-120    | gocertify-200-120    | passcerty-200-120    | certifyguide-70-980    | dumpscollection-70-980    | examcollection-70-534    | cbtnuggets-210-065    | examfiles-400-051    | passitdump-400-051    | pearsonitcertification-70-462    | anderseide-70-347    | thomas-70-533    | research-1V0-605    | topix-102-400    | certdepot-EX200    | pearsonit-640-916    | itproguru-70-533    | reddit-100-105    | channel9-70-346    | anderseide-70-346    | theiia-IIA-CIA-PART3    | certificationHP-hp0-s41    | pearsonitcertification-640-916    | anderMicrosoft-70-534    | cathMicrosoft-70-462    | examcollection-cca-500    | techexams-gcih    | mslearn-70-346    | measureup-70-486    | pass4sure-hp0-s41    | iiba-640-916    | itsecurity-sscp    | cbtnuggets-300-320    | blogged-70-486    | pass4sure-IIA-CIA-PART1    | cbtnuggets-100-101    | developerhandbook-70-486    | lpicisco-101    | mylearn-1V0-605    | tomsitpro-cism    | gnosis-101    | channel9Mic-70-534    | ipass-IIA-CIA-PART1    | forcerts-70-417    | tests-sy0-401    | ipasstheciaexam-IIA-CIA-PART3    | mostcisco-300-135    | buildazure-70-533    | cloudera-cca-500    | pdf4cert-2v0-621    | f5cisco-101    | gocertify-1z0-062    | quora-640-916    | micrcosoft-70-480    | brain2pass-70-417    | examcompass-sy0-401    | global-EX200    | iassc-ICGB    | vceplus-300-115    | quizlet-810-403    | cbtnuggets-70-697    | educationOracle-1Z0-434    | channel9-70-534    | officialcerts-400-051    | examsboost-IIA-CIA-PART1    | networktut-300-135    | teststarter-300-206    | pluralsight-70-486    | coding-70-486    | freeccna-100-101    | digitaltut-300-101    | iiba-CBAP    | virtuallymikebrown-640-916    | isaca-cism    | whizlabs-pmp    | techexams-70-980    | ciscopress-300-115    | techtarget-cism    | pearsonitcertification-300-070    | testking-2v0-621    | isacaNew-cism    | simplilearn-pmi-rmp    | simplilearn-pmp    | educationOracle-1z0-809    | education-1z0-809    | teachertube-1Z0-434    | villanovau-CBAP    | quora-300-206    | certifyguide-300-208    | cbtnuggets-100-105    | flydumps-70-417    | gratisexams-1V0-605    | ituonline-1z0-062    | techexams-cas-002    | simplilearn-70-534    | pluralsight-70-697    | theiia-IIA-CIA-PART1    | itexamtips-400-051    | pearsonitcertification-EX200    | pluralsight-70-480    | learn-hp0-s42    | giac-gpen    | mindhub-102-400    | coursesmsu-CBAP    | examsforall-2v0-621    | developerhandbook-70-487    | root-EX200    | coderanch-1z0-809    | getfreedumps-1z0-062    | comptia-cas-002    | quora-1z0-809    | boson-300-135    | killtest-2v0-621    | learncia-IIA-CIA-PART3    | computer-gcih    | universitycloudera-cca-500    | itexamrun-70-410    | certificationHPv2-hp0-s41    | certskills-100-105    | skipitnow-70-417    | gocertify-sy0-401    | prep4sure-70-417    | simplilearn-cisa    |
http://www.pmsas.pr.gov.br/wp-content/    | http://www.pmsas.pr.gov.br/wp-content/    |