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

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

ただいまの
回答率

88.05%

csv内にあるRSSIとSSIDを組み合わせたものを数えたい

受付中

回答 0

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 458
退会済みユーザー

退会済みユーザー

DB構築のためのプログラム

ここに質問の内容を詳しく書いてください。
JavaでDB構築のためのプログラムを作成しています。
RSSIとSSIDの組み合わせの数を数えたいのですが、それぞれでカウントしてしまい組み合わせたものを数えることができません。
組み合わせの例
SSID                    RSSI> 
c8:b5:ad:32:26:90    -50
60:84:bd:94:68:fc    -56
60:84:bd:94:68:f9    -62
c8:b5:ad:32:26:80    -68

-59~-50 = -50とします。RSSIはそれぞれ-49~-40=-40,-59~-50=-50,-69~-60=-60,-79~-70=-70,-89~-80=-80,-99~-90=-90となります。c8:b5:ad:32:26:90のRSSIが-50のものはいくつあるのかを数えるプログラムを作成したいです。

エラーメッセージ
 csvファイルを読み取れない。また、読み取ってもSSID,RSSIをそれぞれカウントしてしまう。

該当のソースコード

import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.io.File;

public class Ccsv {

    static final String FILE_PATH = "30ms20m.csv";

    public static void main(String[] args) {

        // 集計と読み取り
              Map<String, Integer> map = new HashMap<>();
            try (FileReader fr = new FileReader(FILE_PATH);
                BufferedReader br = new BufferedReader(fr)){
                String line;
                while ((line = br.readLine()) != null) {
                    String[]data = line.split(",",0);
                        for (String elem : data) {
                            if (!elem.isEmpty()) {
                                if (map.containsKey(elem)) {
                                        int count = map.get(elem) + 1;
                                        map.put(elem, count);
                               } else {
                                    map.put(elem, 1);
                            }
                        }

                }

            }
            }catch (FileNotFoundException e) {
                    System.out.println("ファイルが見つかりませんでした。");
            }catch (IOException e) {
                     System.out.println("読み取りに失敗しました。");
            }


               List<String> list = new ArrayList<>();
            int maxLengthOfSpelling = 0;
            for (String key : map.keySet()) {
                    list.add(key);

                    if (maxLengthOfSpelling < key.length()) {
                    maxLengthOfSpelling = key.length();
                }
        }

            Collections.sort(list, (o1, o2) -> {
                    return - map.get(o1) + map.get(o2);
            });

            String format = "%-" + maxLengthOfSpelling + "s: %3d";
            for (String word : list) {
                    int count = map.get(word);
                        if (10 <= count) {
                            System.out.printf(format, word, count);
                            System.out.println();
                    }
            }

         }

}

試したこと

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

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

ここにより詳細な情報を記載してください。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正の依頼

  • Orlofsky

    2019/07/10 17:33

    データベースを使うのかを質問のタグで明示したり、バージョンも明記した方が適切なコメントが付き易いです。https://www.ashisuto.co.jp/corporate/column/technical-column/detail/1197236_2274.html

    キャンセル

  • m.ts10806

    2019/07/10 17:33

    質問は編集できますので、タイトルも含めてご調整ください

    キャンセル

  • m.ts10806

    2019/07/10 17:42

    私の言い方が良くなかったですね・・・
    できればタイトルは「実際に起きている問題」にフォーカスをあてた要件にしてもらえればと思います。
    質問内容に書かれている状況や問題・課題を要約したものですね。
    あまりにカテゴリが大きいものや汎用的すぎると「何が問題か」がタイトルを見ただけでは分かりませんし、同じタイトルで質問を量産することになってしまいます。

    キャンセル

まだ回答がついていません

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

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

関連した質問

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