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

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

ただいまの
回答率

90.51%

  • Java

    13777questions

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

java テキストファイルをcsvへ

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 192

rin_rin0000

score 2

 前提・実現したいこと

eclipse4.5 java8
------------------------------簡略詳細-------------------------------------
txtファイル(パスを変数x、ファイル名をyとする)を読み込み、列に特定の文字を含む行を読み飛ばし
尚且つ読み込んだ後に特定の列を指定して抽出してcsv(エクセルファイル)としたい
~~~~~~~~~~~~~~~~~~~~~~~~

--更に詳しく--
私は下記のように直接ファイルパスを記載し定められたファイル名、尚且つ全ての内容を読み込むことに成功。
txtをcsv出力、そして読み込み後に特定の列をしていして抽出を行いたい。
同時に特定の文字を含む列は読み飛ばすこととする。

情報が少ないかもしれませんが、何卒よろしくお願いいたします。

 該当のソースコード

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

public class Main {

    public static void main(String[] args) {
        try {
            //Fileクラスに読み込むファイルを指定する
            File file = new File("/Users/Shared/java/java.txt");

            //ファイルが存在するか確認する
            if(file.exists()) {

                //FileReaderクラスのオブジェクトを生成する
                FileReader filereader = new FileReader(file);

                //filereaderクラスのreadメソッドでファイルを1文字ずつ読み込む
                int data;
                while((data = filereader.read()) != -1) {
                    System.out.print((char) data);
                }

                //ファイルクローズ
                filereader.close();

            } else {
                System.out.print("ファイルは存在しません");
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

}

 試したこと

ここに問題に対して試したことを記載してください。

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

テキストファイルの中身
1行目 10:30:50 fas ghd #dasfs fdsf  herge %#das
2行目 12:42:43 1   2   432    geds  41    gds!!#
3行目 14:32:31 abb sa  4vs    dss23 123   fs2

実現したいcsv形式
1行目 10:30:50 fas #dasfs %#das
2行目 12:42:43 1   432    gds!!#
3行目 14:32:31 abb sa    fs2

のような形です。 よろしくお願いします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • euledge

    2018/07/14 06:45

    テキストファイルの中身を2,3行で良いので例示して、結果としてどのようなCSVファイルになるのかを質問に追記してください

    キャンセル

回答 1

checkベストアンサー

+1

txtファイル(パスを変数x、ファイル名をyとする)を読み込み、列に特定の文字を含む行を読み飛ばし
尚且つ読み込んだ後に特定の列を指定して抽出してcsv(エクセルファイル)としたい

サンプルで提示された空白区切りのテキストファイルをCSVファイルにするというところは理解できますが、特定文字を含む行の読み飛ばしについては条件が不明なので、適当に決めた文字を含まない行に対して指定された列からCSVを作るというところまで書いてみました。

  • 文字列に指定した文字が含まれるか String#contains
  • 文字列から区切り文字で分割した配列を作る String#split
  • 文字列配列から区切り文字で結合した文字列を作る String#join

この3つが肝です。

ファイルから1文字ずつ読み出すのは今回の処理ではあまり向かないと思いますので行単位での読み出しにしてJava8っぽい記述にしてみました。

    // 仮に決めた不要な行と判断する文字
    String ignoreChar = "%";
    // 仮に決めた出力対象の列 但し先頭列を0とする
    int[] index = {0,2,4,6};

    String filePath = "/Users/Shared/java/java.txt";
    if (Files.exists(Paths.get(filePath))) {
      try (Stream<String> stream = Files.lines(Paths.get(filePath), StandardCharsets.UTF_8)) {
        stream.forEach(line -> {
          if (!line.contains(ignoreChar)) {
            // 文字列を空白区切りで配列に変換する
            String[] columns = line.split("\\s+", 0);
            // このような配列になる
            // [10:30:50, fas, ghd, #dasfs, fdsf, herge, %#das] 

            // 指定した列のみ出力するために先に決めていたindexで指定された列で配列を作り直す
            String[] filterd = {
               columns[index[0]],
               columns[index[1]],
               columns[index[2]],
               columns[index[3]],
            };
            // 文字列配列をカンマ区切りの文字列に変換する
            String csvRow = String.join(",", filterd);
            System.out.println(csvRow);
          }
        });
      } catch (IOException e) {
        e.printStackTrace();
      }
    } else {
      System.out.print("ファイルは存在しません");
    }
  }

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.51%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 受付中

    初歩段階プログラミング

    お世話になります。 使用言語はJavaです。 プログラム中にある名前を全て出力するプログラムを作りたいのですが 初心者でうまく組む事ができません。 条件 このプログラムでの"名前

  • 受付中

    csvの抽出条件について質問です

    csvファイルの読み込みにキーボード入力をした文字と一致するものを抽出させるプログラムをつくっています。 ただ読み込むだけならできるのですが、それに条件をつけると読み込めなくなりま

  • 受付中

    ファイルのコピー

    Java開発初心者です。 ファイルのコピーを行うコードを書いています。 FileInputStreamとFileOutputStreamを使って、 コピーしたいファイ

  • 解決済

    フォルダの中にあるファイルを1つずつ読み込む

    最近Javaで開発を始めました。 複数のファイルが入っているフォルダがあります。 このフォルダから1ファイルずつ開き中身をバッファか配列に読み込むコードを書きたいです。

  • 受付中

    プログラムソースを教えて欲しいです

    前提・実現したいこと しりとりプログラムを作ろうとしています。 CSVデータ中の情報を読み込みデータ内の単語のみでしりとりを行います。 ルールとして ・CPUとの対戦型

  • 解決済

    javaでデータを読み込んでソートしたいのですがうまく来ません

    コンパイルするとエラーになって 「シンボルが見つかりません」と表示されます。 他にも問題があれば教えてください import java.io.File; import

  • 解決済

    会員情報システム(Java)での作り方

    javaで会員情報システムのようなものを作りたいです。 下記の実行結果(コマンドプロンプトで実行)になるような、登録プログラムを作成したいのですが、作成方法が分かりませんので、教

  • 解決済

    ファイルの書き出し

    前提・実現したいこと csvファイルから読み込んだものをソートして別のcsvファイルに書き出しを行いたいです。 発生している問題・エラーメッセージ 書き出しが行われない。

同じタグがついた質問を見る

  • Java

    13777questions

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