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

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

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

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

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

Q&A

解決済

1回答

5730閲覧

CSVからの読み込み時、不要な行を削除して読み込みを行いたい

tennis

総合スコア19

Java

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

Spring Boot

Spring Bootは、Javaのフレームワークの一つ。Springプロジェクトが提供する様々なフレームワークを統合した、アプリケーションを高速で開発するために設計されたフレームワークです。

0グッド

0クリップ

投稿2020/06/18 02:16

問題

以下のCSVファイルを読み込む際、最初の行「名前、年齢、職業」を除いたところから読み込みを行いたい。

CSV

イメージ説明

Java

SampleController

1package com.example; 2 3import java.io.BufferedReader; 4import java.io.IOException; 5import java.io.InputStream; 6import java.io.InputStreamReader; 7import java.io.Reader; 8import java.util.ArrayList; 9import java.util.List; 10 11import org.springframework.beans.factory.annotation.Autowired; 12import org.springframework.stereotype.Controller; 13import org.springframework.web.bind.annotation.RequestMapping; 14import org.springframework.web.bind.annotation.RequestParam; 15import org.springframework.web.multipart.MultipartFile; 16 17@Controller 18@RequestMapping("/") 19public class SampleController { 20 21@Autowired 22private SampleMapper mapper; 23 24 @RequestMapping("/insert") 25 private void fileContents(@RequestParam("upload_file")MultipartFile uploadFile) { 26 27 List<String> lines = new ArrayList<String>(); 28 29 String line = null; 30 31 try { 32 InputStream stream = uploadFile.getInputStream(); 33 Reader reader = new InputStreamReader(stream); 34 BufferedReader buf= new BufferedReader(reader); 35 36 while((line = buf.readLine()) != null) { 37 38 String[] data = line.split(",", 0); 39 40 User user = new User(); 41 user.setUserName(data[0]); 42 user.setAge(Integer.parseInt(data[1])); 43 user.setOccupation(data[2]); 44 45 mapper.insert(user); 46 47 lines.add(line); 48 } 49 50 line = buf.readLine(); 51 52 } catch (IOException e) { 53 54 line = "Can't read contents."; 55 lines.add(line); 56 e.printStackTrace(); 57 58 } 59 } 60}

現状

これだと、最初の名前、年齢、職業も入ってきてしまうため、うまくDBにインサートができません。
読み込みの際に最初の1行を読み込まない方法をご教授ください。お願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

お疲れさまです。

あまりスマートな方法ではないかもしれませんが、読み込んだCSVデータを数えるカウンタを作り、
if文でタイトル行は読むけどDBに書き込まないとしてはどうですか。
あくまでも1行目がタイトルという前提です。
あと、DBに各処理はmapper.insert(user);はこれかなと思いましたが、
lines.add(line);も一緒に囲んでしまいました。
適当に修正してください。

String line = null; int csfCount = 0; //追加 try { InputStream stream = uploadFile.getInputStream(); Reader reader = new InputStreamReader(stream); BufferedReader buf= new BufferedReader(reader); while((line = buf.readLine()) != null) { csvCount++; //追加 String[] data = line.split(",", 0); User user = new User(); user.setUserName(data[0]); user.setAge(Integer.parseInt(data[1])); user.setOccupation(data[2]); if(csvCount > 1){ //追加 mapper.insert(user); lines.add(line); } } line = buf.readLine(); } catch (IOException e) {

投稿2020/06/18 07:52

編集2020/06/18 09:53
senior_golfer

総合スコア267

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

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

tennis

2020/06/19 00:08

コードを参考にやってみたところ解決することができました!ありがとうございました!
TN8001

2020/06/19 03:23

読み飛ばすならwhileの前に、buf.readLine()を1個入れるだけで十分では?
tennis

2020/06/19 13:17

試してみたらできました!ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問