Скидки до 81 000 руб и профессия в подарок!

Как читать столбцы в файле csv java

Аватар пользователя Иван Полежаев
Иван Полежаев
14 апреля 2023

Для чтения столбцов в файле CSV в Java можно использовать библиотеку OpenCSV. Для этого необходимо выполнить следующие шаги:

  • Добавить зависимость в файл build.gradle или pom.xml:

Gradle:

dependencies {
    implementation 'com.opencsv:opencsv:5.5.2'
}

Maven:

<dependencies>
    <dependency>
        <groupId>com.opencsv</groupId>
        <artifactId>opencsv</artifactId>
        <version>5.5.2</version>
    </dependency>
</dependencies>
  • Импортировать классы CSVReader и CSVReaderBuilder из пакета com.opencsv
  • Создать объект CSVReader и передать ему Reader объект, созданный на основе файла CSV:
Copy code
CSVReader csvReader = new CSVReaderBuilder(new FileReader("file.csv")).build();
  • Прочитать строки из файла с помощью метода readNext():
String[] nextLine;
while ((nextLine = csvReader.readNext()) != null) {
    // Обработка строки
}
  • Для чтения столбцов можно использовать индексы элементов массива nextLine:
String firstColumn = nextLine[0];
String secondColumn = nextLine[1];
// и т.д.
  • Не забудьте закрыть объект CSVReader после использования:
csvReader.close();

Пример кода:

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

import java.io.FileReader;
import java.io.IOException;

public class CsvReaderExample {
    public static void main(String[] args) throws IOException {
        CSVReader csvReader = new CSVReaderBuilder(new FileReader("file.csv")).build();

        String[] nextLine;
        while ((nextLine = csvReader.readNext()) != null) {
            String firstColumn = nextLine[0];
            String secondColumn = nextLine[1];
            // и т.д.

            System.out.println(firstColumn + " " + secondColumn);
        }

        csvReader.close();
    }
}
  • В конструкторе класса передается объект FileReader, который открывает файл для чтения.
  • Далее происходит чтение каждой строки файла с помощью метода readNext().
  • Этот метод возвращает массив строк, содержащий значения столбцов текущей строки.
  • Каждое значение сохраняется в отдельной переменной, которую можно использовать для вывода в консоль или для обработки в коде дальше.
0 0

Есть что добавить? Зарегистрируйтесь

или войдите в аккаунт

Отправляя форму, вы принимаете «Соглашение об обработке персональных данных» и условия «Оферты», а также соглашаетесь с «Условиями использования»

Курсы по программированию в Хекслете

Программирование

Веб-разработка

Разработка, верстка и деплой сайтов и веб-приложений, трудоустройство для разработчиков

Frontend-разработка

Разработка внешнего интерфейса сайтов и веб-приложений и верстка

Создание сайтов

Разработка сайтов и веб-приложений на JS, Python, Java, PHP и Ruby on Rails

Backend-разработка

Разработка серверной части сайтов и веб-приложений

Тестирование

Ручное тестирование и автоматизированное тестирование на JS, Python, Java и PHP

Аналитика данных

Сбор, анализ и интерпретация данных на Python

Интенсивные курсы

Интенсивное обучение для продолжающих

DevOps

Автоматизация настройки локального окружения и серверов, развертывания и деплоя

Математика для программистов

Обучение разделам математики, которые будут полезны при изучении программирования

Тест-драйв

JavaScript

Разработка сайтов и веб-приложений и автоматизированное тестирование на JS

Python

Веб-разработка, автоматическое тестирование и аналитика данных на Python

Java

Веб-разработка и автоматическое тестирование на Java

PHP

Веб-разработка и автоматическое тестирование на PHP

Ruby

Разработка сайтов и веб-приложений на Ruby on Rails

Go

Курсы по веб-разработке на языке Go

HTML

Современная верстка с помощью HTML и CSS

SQL

Проектирование базы данных, выполнение SQL-запросов и изучение реляционных СУБД

Git

Система управления версиями Git, регулярные выражения и основы командой строки

Бесплатные курсы

Бесплатные курсы по тестированию, дата-аналитике, верстке, программированию на Python, Java, PHP и JavaScript.

Похожие вопросы

1
ответ
1
ответ
2
ответа