Maison > Java > javaDidacticiel > Explication détaillée de la lecture et de l'écriture de fichiers CSV en Java à l'aide d'OpenCSV

Explication détaillée de la lecture et de l'écriture de fichiers CSV en Java à l'aide d'OpenCSV

王林
Libérer: 2023-12-20 09:36:52
original
1630 Les gens l'ont consulté

Java 中使用 OpenCSV 实现 CSV 文件的读写操作指南

Java est un langage de programmation largement utilisé et les développeurs doivent souvent gérer différents formats de données. CSV (Comma-Separated Values) est un format de données courant largement utilisé dans l'échange et le stockage de données. En Java, nous pouvons utiliser la bibliothèque OpenCSV pour lire et écrire des fichiers CSV.

OpenCSV est une bibliothèque open source facile à utiliser qui fournit une API pratique pour traiter les données CSV. Cet article explique comment utiliser OpenCSV pour lire et écrire des fichiers CSV en Java.

1. Ajouter une dépendance OpenCSV

Tout d'abord, nous devons ajouter une dépendance OpenCSV au projet. Les dépendances du projet peuvent être gérées via Maven, ajoutez simplement le code suivant dans le fichier pom.xml :

<dependency>
    <groupId>com.opencsv</groupId>
    <artifactId>opencsv</artifactId>
    <version>5.5.1</version>
</dependency>
Copier après la connexion

2 Lire les fichiers CSV

Pour lire les fichiers CSV, nous devons créer un objet CSVReader et l'utiliser pour lire les données d'un fichier. . Voici un exemple simple :

import com.opencsv.CSVReader;

public class CSVReaderExample {
    public static void main(String[] args) {
        try {
            CSVReader reader = new CSVReader(new FileReader("data.csv"));
            String[] line;
            while ((line = reader.readNext()) != null) {
                for (String value : line) {
                    System.out.print(value + " ");
                }
                System.out.println();
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
Copier après la connexion

Dans l'exemple ci-dessus, nous créons d'abord un objet CSVReader et transmettons le chemin du fichier CSV à lire. Nous utilisons ensuite la méthode readNext() pour lire les données du fichier ligne par ligne jusqu'à atteindre la fin du fichier. readNext() 方法来逐行读取文件中的数据,直到到达文件的末尾。

3. 写入 CSV 文件

要写入 CSV 文件,我们需要创建一个 CSVWriter 对象,并使用它来写入数据。以下是一个简单的例子:

import com.opencsv.CSVWriter;

public class CSVWriterExample {
    public static void main(String[] args) {
        try {
            CSVWriter writer = new CSVWriter(new FileWriter("data.csv"));
            String[] line1 = {"John", "Doe", "30"};
            String[] line2 = {"Jane", "Smith", "25"};
            writer.writeNext(line1);
            writer.writeNext(line2);
            writer.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
Copier après la connexion

在上面的例子中,我们首先创建了一个 CSVWriter 对象,并传入要写入的 CSV 文件的路径。然后,我们使用 writeNext() 方法来写入一行数据。最后,我们关闭 CSVWriter 对象。

4. 使用 CSVReaderOptions 和 CSVWriterOptions

除了基本的读写操作之外,OpenCSV 还提供了一些高级功能,如 CSVReaderOptions 和 CSVWriterOptions。使用这些选项,我们可以设置 CSV 文件的分隔符、引号等属性。

以下是一个使用 CSVReaderOptions 的例子:

import com.opencsv.CSVReader;
import com.opencsv.CSVReaderBuilder;

public class CSVReaderOptionsExample {
    public static void main(String[] args) {
        try {
            CSVReaderBuilder builder = new CSVReaderBuilder(new FileReader("data.csv"))
                    .withSeparator(',')
                    .withQuoteChar('"')
                    .withSkipLines(1);
            CSVReader reader = builder.build();
            String[] line;
            while ((line = reader.readNext()) != null) {
                for (String value : line) {
                    System.out.print(value + " ");
                }
                System.out.println();
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
Copier après la connexion

在上面的例子中,我们首先创建了一个 CSVReaderBuilder 对象,并传入要读取的 CSV 文件的路径。然后,我们使用 withSeparator() 方法来设置分隔符为逗号,withQuoteChar() 方法来设置引号为双引号,withSkipLines()

3. Écrire un fichier CSV

Pour écrire un fichier CSV, nous devons créer un objet CSVWriter et l'utiliser pour écrire des données. Voici un exemple simple :

rrreee

Dans l'exemple ci-dessus, nous créons d'abord un objet CSVWriter et transmettons le chemin du fichier CSV à écrire. Ensuite, nous utilisons la méthode writeNext() pour écrire une ligne de données. Enfin, nous fermons l'objet CSVWriter.

4. Utilisez CSVReaderOptions et CSVWriterOptions🎜🎜En plus des opérations de lecture et d'écriture de base, OpenCSV fournit également des fonctions avancées, telles que CSVReaderOptions et CSVWriterOptions. En utilisant ces options, nous pouvons définir des propriétés telles que des délimiteurs, des guillemets, etc. du fichier CSV. 🎜🎜Ce qui suit est un exemple d'utilisation de CSVReaderOptions : 🎜rrreee🎜Dans l'exemple ci-dessus, nous créons d'abord un objet CSVReaderBuilder et transmettons le chemin du fichier CSV à lire. Ensuite, nous utilisons la méthode withSeparator() pour définir le séparateur sur virgule, la méthode withQuoteChar() pour définir les guillemets sur guillemets doubles, withSkipLines() Méthode permettant de définir les premières lignes de données du fichier à ignorer. 🎜🎜De même, nous pouvons également utiliser CSVWriterOptions pour définir les options d'écriture des fichiers CSV. 🎜🎜Conclusion🎜🎜OpenCSV est une bibliothèque puissante et facile à utiliser qui facilite la lecture et l'écriture de fichiers CSV. Cet article présente un guide pour lire et écrire des fichiers CSV à l'aide d'OpenCSV en Java. J'espère que cet article vous aidera à mieux travailler avec les données CSV. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal