質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

2回答

1201閲覧

Java: 5つの400項目あるCSVファイルを結合して1つの2000項目のファイルにするには?

EXEMG

総合スコア7

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2018/07/23 10:13

現在、Javaで5つの400項目あるCSVファイルを取り込み、それぞれの列を結合して1つの2000項目のファイルにして出力するプログラムを組んでいます。
しかしながら、Javaはあまり触れたことがなく、どのように実装すればよいかアイディアが浮かばず止まっています。
どのような処理を使えばよいでしょうか?
ご教示お願い致します。

一つ試している方法は
それぞれ5つのファイルをArrayList<String[]>で取り込み、1つのArrayList<String[]>にして
新たに出力する方法をとろうとしましたがエラーが出てとん挫しております。

以下、そのコードです。

package routines;

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays;

public class CSVWriterReader {

/** * main * @param args the command line arguments */ public static void CSVExcute(String file_name) { String filename_1 = file_name.substring(0, file_name.length() - 4) + "1" + ".csv" ; String filename_2 = file_name.substring(0, file_name.length() - 4) + "2" + ".csv" ; String filename_3 = file_name.substring(0, file_name.length() - 4) + "3" + ".csv" ; String filename_4 = file_name.substring(0, file_name.length() - 4) + "4" + ".csv" ; String filename_5 = file_name.substring(0, file_name.length() - 4) + "5" + ".csv" ; /*read CSV*/ CSVScanner csvscan_1 = new CSVScanner(new File(filename_1)); CSVScanner csvscan_2 = new CSVScanner(new File(filename_2)); CSVScanner csvscan_3 = new CSVScanner(new File(filename_3)); CSVScanner csvscan_4 = new CSVScanner(new File(filename_4)); CSVScanner csvscan_5 = new CSVScanner(new File(filename_5)); ArrayList<String[]> csv_data_1 = csvscan_1.read(); ArrayList<String[]> csv_data_2 = csvscan_2.read(); ArrayList<String[]> csv_data_3 = csvscan_3.read(); ArrayList<String[]> csv_data_4 = csvscan_4.read(); ArrayList<String[]> csv_data_5 = csvscan_5.read(); //String[] array = csvscan.toArray(new String[csvscan.size()]); ArrayList<String[]> csv_data = new ArrayList<String[]>(); long arrayitems = csv_data_1.size(); for (int i =0;i<arrayitems;i++){ StringBuilder buf = new StringBuilder(); buf.append(csv_data_1.get(i)); buf.append(csv_data_2.get(i)); buf.append(csv_data_3.get(i)); buf.append(csv_data_4.get(i)); buf.append(csv_data_5.get(i)); String lineword = buf.toString(); csv_data.add(lineword);              ←※ここの"add"でエラー } /*write CSV*/ //CSVPrintWriter csvpw = new CSVPrintWriter(file_name , true); try{ File csvpw = new File(file_name); FileWriter filewriter = new FileWriter(csvpw, true); for (int i =0;i<arrayitems;i++){ filewriter.write(csv_data.get(i) + "¥r¥n"); } filewriter.close(); }catch(IOException e){ System.out.println(e); }

// csv_data.stream().forEach(
//
// //line->System.out.println(Arrays.toString(line))
// line->csvpw.println(Arrays.toString(line))
//
// );
//csvpw.println(csv_data);

csvscan_1.close(); csvscan_2.close(); csvscan_3.close(); csvscan_4.close(); csvscan_5.close(); //csvpw.close(); }

}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

Javaの勉強目的じゃなくて、ファイルを結合すれば良いだけであれば、Linuxコマンドで一発です。

Bash

1paste -d, file1 file2 file3 file4 file5 > fileout

投稿2018/07/23 11:07

otn

総合スコア84499

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

EXEMG

2018/07/31 00:14

ありがとうございます。 今回はユーザー環境がwindowsでubuntuが入ってないこともあり、 別の方法で独自に解決方法を考え付いたので直接の助けになりませんでした。 しかしながら、bashを使うという新しい発想が生まれたのでベストアンサーとさせていただきます。
guest

0

オブジェクトは勝手に配列にはならないので
[]を除去しよう

投稿2018/07/23 10:47

編集2018/07/23 10:48
退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

EXEMG

2018/07/31 00:17

二次元配列のエラーの解決方法を期待していたので申し訳ございませんが他の方をベストアンサーとさせていただきました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問