java - जावा के लिए सीएसवी एपीआई





csv (9)


हम JavaCSV उपयोग JavaCSV , यह बहुत अच्छी तरह से काम करता है

क्या कोई एक साधारण एपीआई की सिफारिश कर सकता है जो मुझे एक CSV इनपुट फ़ाइल पढ़ने का उपयोग करने की अनुमति देगा, कुछ सरल परिवर्तन करें, और फिर इसे लिखें।

एक त्वरित Google को http://flatpack.sourceforge.net/ मिला है जो आशाजनक दिखता है।

मैं सिर्फ यह जांचना चाहता था कि मैं इस एपीआई में खुद को जोड़ने से पहले दूसरों का क्या उपयोग कर रहा हूं।




सीएसवी प्रारूप स्ट्रिंगटोकनाइज़र के लिए काफी आसान लगता है लेकिन यह अधिक जटिल हो सकता है। यहां जर्मनी में एक अर्धविराम का उपयोग एक डिलीमीटर के रूप में किया जाता है और कोशिकाएं युक्त कोशिकाओं से बचने की आवश्यकता होती है। आप स्ट्रिंगटोकनाइज़र के साथ आसानी से इसे संभालने वाले नहीं हैं।

मैं http://sourceforge.net/projects/javacsv लिए जाऊंगा




आखिरी एंटरप्राइज़ एप्लिकेशन के लिए मैंने सीएसवी की एक उल्लेखनीय राशि को संभालने के लिए जरूरी काम किया - कुछ महीने पहले - मैंने SuperCSV पर SuperCSV इस्तेमाल किया और इसे सरल, मजबूत और समस्या मुक्त पाया।




सीएसवी प्रारूप विवरण पढ़ना मुझे महसूस करता है कि तृतीय पक्ष लाइब्रेरी का उपयोग करके इसे स्वयं लिखने से कम सिरदर्द होगा:

विकिपीडिया 10 या कुछ ज्ञात पुस्तकालयों की सूची देता है:

मैंने किसी प्रकार की चेक सूची का उपयोग करके सूचीबद्ध लिबियों की तुलना की। ओपनसीएसवी ने निम्नलिखित परिणामों के साथ मुझे एक विजेता ( वाईएमएमवी ) बनाया:

+ maven

+ maven - release version   // had some cryptic issues at _Hudson_ with snapshot references => prefer to be on a safe side

+ code examples

+ open source   // as in "can hack myself if needed"

+ understandable javadoc   // as opposed to eg javadocs of _genjava gj-csv_

+ compact API   // YAGNI (note *flatpack* seems to have much richer API than OpenCSV)

- reference to specification used   // I really like it when people can explain what they're doing

- reference to _RFC 4180_ support   // would qualify as simplest form of specification to me

- releases changelog   // absence is quite a pity, given how simple it'd be to get with maven-changes-plugin   // _flatpack_, for comparison, has quite helpful changelog

+ bug tracking

+ active   // as in "can submit a bug and expect a fixed release soon"

+ positive feedback   // Recommended By 51 users at sourceforge (as of now)



अपाचे कॉमन्स सीएसवी

apache से एक को देखें।




यदि आप एक्सेल से सीएसवी पढ़ना चाहते हैं, तो कुछ दिलचस्प कोने के मामले हैं। मैं उन सभी को याद नहीं कर सकता, लेकिन अपाचे कॉमन्स सीएसवी इसे सही तरीके से संभालने में सक्षम नहीं था (उदाहरण के लिए, यूआरएल)।

कोट्स और कॉमा के साथ एक्सेल आउटपुट का परीक्षण करना सुनिश्चित करें और पूरे स्थान पर स्लेश करें।







आप csvreader api का उपयोग कर सकते हैं और निम्न स्थान से डाउनलोड कर सकते हैं:

http://sourceforge.net/projects/javacsv/files/JavaCsv/JavaCsv%202.1/javacsv2.1.zip/download

या

JavaCSV

निम्नलिखित कोड का प्रयोग करें:

/ ************ For Reading ***************/

import java.io.FileNotFoundException;
import java.io.IOException;

import com.csvreader.CsvReader;

public class CsvReaderExample {

    public static void main(String[] args) {
        try {

            CsvReader products = new CsvReader("products.csv");

            products.readHeaders();

            while (products.readRecord())
            {
                String productID = products.get("ProductID");
                String productName = products.get("ProductName");
                String supplierID = products.get("SupplierID");
                String categoryID = products.get("CategoryID");
                String quantityPerUnit = products.get("QuantityPerUnit");
                String unitPrice = products.get("UnitPrice");
                String unitsInStock = products.get("UnitsInStock");
                String unitsOnOrder = products.get("UnitsOnOrder");
                String reorderLevel = products.get("ReorderLevel");
                String discontinued = products.get("Discontinued");

                // perform program logic here
                System.out.println(productID + ":" + productName);
            }

            products.close();

        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }

    }

}

सीएसवी फ़ाइल लिखें / संलग्न करें

कोड:

/************* For Writing ***************************/

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;

import com.csvreader.CsvWriter;

public class CsvWriterAppendExample {

    public static void main(String[] args) {

        String outputFile = "users.csv";

        // before we open the file check to see if it already exists
        boolean alreadyExists = new File(outputFile).exists();

        try {
            // use FileWriter constructor that specifies open for appending
            CsvWriter csvOutput = new CsvWriter(new FileWriter(outputFile, true), ',');

            // if the file didn't already exist then we need to write out the header line
            if (!alreadyExists)
            {
                csvOutput.write("id");
                csvOutput.write("name");
                csvOutput.endRecord();
            }
            // else assume that the file already has the correct header line

            // write out a few records
            csvOutput.write("1");
            csvOutput.write("Bruce");
            csvOutput.endRecord();

            csvOutput.write("2");
            csvOutput.write("John");
            csvOutput.endRecord();

            csvOutput.close();
        } catch (IOException e) {
            e.printStackTrace();
        }

    }
}



जीयूआई कोड में इसका एक आम उदाहरण है जब विजेट / घटक बनाते हैं और कुछ स्थैतिक / एप्लिकेशन स्कोप्ड ऑब्जेक्ट में श्रोता जोड़ते हैं और फिर विजेट नष्ट होने पर श्रोता को हटा नहीं देते हैं। न केवल आपको स्मृति रिसाव मिलती है, बल्कि जब भी आप घटनाओं को आग लगाना सुनते हैं तो प्रदर्शन भी प्रभावित होता है, आपके सभी पुराने श्रोताओं को भी बुलाया जाता है।





java csv