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

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

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

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

Java

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Q&A

解決済

1回答

463閲覧

Javaのオブジェクト指向でcsvファイルを読み込み、新たなcsvファイルに出力する時のエラー

退会済みユーザー

退会済みユーザー

総合スコア0

CSV

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

Java

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

0グッド

0クリップ

投稿2018/05/23 02:56

前提・実現したいこと

参考資料に記載されているコードを元に
Javaのオブジェクト指向で書かれたプログラムで
csvファイルを読み込み形式はそのままで新たなcsvファイルを
書き出そうとしています。

前回の質問では形式を変更していたのですが、
今回はコピーではなく、
そのままの形式で一度オブジェクトのメンバとした
上で新たなcsvファイルに出力しようとしています。

前回の質問
参考資料

発生している問題・エラーメッセージ

csvTestクラスの以下の部分でエラーが表示されています。

このエラーを無くし、String型でcsvファイルを出力するにはコードを
どのように修正すればいいでしょうか。

この行に複数マーカーがあります - メソッド print(String) は型 BufferedReader で未定義です - 行ブレークポイント:csvTest [行: 44] - main(String[], BufferedReader) - BufferedReader から PrintWriter へキャストすることはできません
//itemListの中身を順に出力する for (Item item : itemList) { outputLine.print(item.getName() + ","); outputLine.print(item.getProductarea() + ","); outputLine.print(item.getProducer() + ","); outputLine.println(); }

該当のソースコード

csvTestクラス

Java

1 2//Java.ioパッケージ 3import java.io.BufferedReader; 4import java.io.FileReader; 5import java.io.FileWriter; 6import java.io.IOException; 7import java.io.PrintWriter; 8import java.util.ArrayList; 9import java.util.List; 10import java.util.StringTokenizer; 11 12public class csvTest { 13 14 public static void main(String[] args, BufferedReader outputLine) { 15 List<Item> itemList = new ArrayList<Item>(); //データ格納用リスト 16 String input = "itemSample.csv";//String型でファイル名を指定する 17 String output = "itemSampleout.csv"; 18 19 try { 20 BufferedReader InputLine = new BufferedReader(new FileReader(input)); 21 PrintWriter outputLine1 = new PrintWriter(new FileWriter(output)); 22 String line; 23 24 line = InputLine.readLine(); //ヘッダを読み込む 25 outputLine1.println(line); //ヘッダを書き込む 26 27 //1行ずつ読み込み 28 while ((line = InputLine.readLine()) != null) { //String変数lineに格納 29 StringTokenizer st = new StringTokenizer(line); //lineを分割の対象にする 30 31 Item item = new Item(); //Itemクラスのインスタンスを作成 32 //フィールドの設定を行う 33 //String型をInteger型に変更 34 /* 35 item.setName(Integer.parseInt(st.nextToken(","))); 36 item.setProductarea(Integer.parseInt(st.nextToken(","))); 37 item.setProducer(Integer.parseInt(st.nextToken(","))); 38 */ 39 itemList.add(item); //リストに追加する 40 } 41 42 //itemListの中身を順に出力する 43 for (Item item : itemList) { 44 outputLine.print(item.getName() + ","); 45 outputLine.print(item.getProductarea() + ","); 46 outputLine.print(item.getProducer() + ","); 47 outputLine.println(); 48 } 49 //開いていた出入力ファイルを閉じる 50 InputLine.close(); 51 outputLine.close(); 52 53 } catch (IOException e) { 54 System.out.println("ファイルが開けません"); 55 } 56 } 57 58} 59

Itemクラス

java

1 2public class Item { 3 //フィールド 4 //メンバはprivate, メソッドはpublic 5 private String name; 6 private String area; 7 private String producer; 8 9 //メンバにはgetter, setterメソッドでアクセスする 10 public String getName() { 11 return name; 12 } 13 14 public void setName(String name) { 15 this.name = name; 16 } 17 18 public String getProductarea() { 19 return area; 20 } 21 22 public void setProductarea(String area) { 23 this.area = area; 24 } 25 26 public int getProducer() { 27 return producer; 28 } 29 30 public void setProducer(String producer) { 31 this.producer = producer; 32 } 33}

補足情報(FW/ツールのバージョンなど)

Eclipse Java EE IDE for Web Developers.
Version: Oxygen.3a Release (4.7.3a)

Microsoft Excel for Mac バージョン16.13

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

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

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

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

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

guest

回答1

0

ベストアンサー

main(String[] args, BufferedReader outputLine)

↑まず、ここから「なんじゃこりゃ?」なわけですが。。。
一般的には「main(String[] args)」やで。。。

//itemListの中身を順に出力する for (Item item : itemList) { outputLine.print(item.getName() + ",");

↑キミ、なんでBufferedReaderにprintさせようとしとんねん。。。

投稿2018/05/23 03:16

tkturbo

総合スコア5572

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

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

退会済みユーザー

退会済みユーザー

2018/05/23 03:52

ご回答いただきましてありがとうございます。 Eclipseのエラーが解決策として提案してきたものをそのまま使用していました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問