Androidアプリで、今日公開された東京電力の電気使用状況csvファイルを取得してみました。
意外と簡単にファイル取得って出来るのね。
前回のボタンを押した時のイベントでcsvファイルを取得する様にしてあります。
ネットに接続させる方法はこちら
- URLを設定する
- 接続するためのオブジェクトを取得する
- データのGETを設定する
- 設定したURLへ接続を開始する
- データ取得後、接続を閉じる
と言う感じの流れでデータの取得が出来ました。
サンプルはこんな感じ
[java]
public void onClick(View arg0) {
if(arg0 == Btn01){
try{
String array[] = null;
String nowPeak = “No Data”;
/* データ取得 */
URL url = new URL(“http://www.tepco.co.jp/forecast/html/images/juyo-j.csv”);
HttpURLConnection http = (HttpURLConnection)url.openConnection();
http.setRequestMethod(“GET”);
http.connect();
/* データ読込 */
BufferedReader reader = new BufferedReader(new InputStreamReader(http.getInputStream()));
/* 解析 */
while (true){
String line = reader.readLine();
if ( line == null ){
break;
}
if(line.indexOf(“,”) != -1){
array = line.split(“,”);
if(!(line.substring(0,4)).equals(“DATE”)){
if(!array[2].equals(“0”)){
nowPeak = array[1] + “のピーク電力は” + array[2] + “万kW”;
}
}
}
}
/* 文字列表示 */
Btn01.setText(nowPeak);
/* 接続終了 */
http.disconnect();
reader.close();
/* エラー処理 */
}catch(Exception e){
Btn01.setText(e.toString());
}
}
}
[/java]
ここでURLを指定して、ファイルに接続しに行くには
URL url = new URL(“http://www.tepco.co.jp/forecast/html/images/juyo-j.csv”);
HttpURLConnection http = (HttpURLConnection)url.openConnection();
http.setRequestMethod(“GET”);
http.connect();
続いてはデータを読み込むには
BufferedReader reader = new BufferedReader(new InputStreamReader(http.getInputStream()));
後、Manifestファイルにインターネットに接続するよ?って宣言が必要です。
<uses-permission android:name=”android.permission.INTERNET”></uses-permission>
これでcsvファイルを読み込んで、最新の電力ピーク状況を取得出来ます。
ただし、これだとボタンを押す毎にファイルを取得しに行ってしまうのが問題ですね。
データを保存して、時間が経っていたらファイルを取得するように変更する必要があるかな。
Tags: Android