2

アプリケーションによって生成された結果を保存するために、Table() 関数を実装しました。ただし、アプリケーションのタイマー機能により、アプリケーションが実行されるたびに既存の CSV ファイルが上書きされるようです。既存のCSVファイルを上書きするのではなく、最新の検索結果を既存のCSVファイルに追記したい。これを行う方法はありますか?結果が JSON などの別の形式で保存されている場合、結果を追加するのは簡単ですか?

Timer timer;
import java.util.List;
Table table;
long lastID = Long.MAX_VALUE;

void setup() {

  timer = new Timer(30000);
  timer.start();
  goTwitter();

  table = new Table();
  table.addColumn("id");
  table.addColumn("latitude");
  table.addColumn("longitude");

} 

void draw(){
   if (timer.isFinished()){
     goTwitter();
     timer.start();
   }
}

void goTwitter(){

  ConfigurationBuilder cb = new ConfigurationBuilder();
  cb.setOAuthConsumerKey("");
  cb.setOAuthConsumerSecret("");
  cb.setOAuthAccessToken("");
  cb.setOAuthAccessTokenSecret("");


Twitter twitter = new TwitterFactory(cb.build()).getInstance();
  Query query = new Query("#love"); 
  int numberOfTweets = 300; 
  ArrayList<Status> tweets = new ArrayList<Status>();
  while (tweets.size () < numberOfTweets) {
    if (numberOfTweets - tweets.size() > 100)
      query.setCount(100);
    else 
      query.setCount(numberOfTweets - tweets.size());
      //long lastID = Long.MAX_VALUE;
    try {
      QueryResult result = twitter.search(query);
      tweets.addAll(result.getTweets());
      println("Gathered " + tweets.size() + " tweets");
      for (Status t: tweets) 
        if(t.getId() < lastID) lastID = t.getId();
    }
    catch (TwitterException te) {
      println("Couldn't connect: " + te);
    }; 
    query.setSinceId(lastID);

  }
  for (int i = 0; i < tweets.size(); i++) {
    Status t = (Status) tweets.get(i);

    GeoLocation loc = t.getGeoLocation();

    String user = t.getUser().getScreenName();
    String msg = t.getText();
    String time = "";
    if (loc!=null) {
      Double lat = t.getGeoLocation().getLatitude();
      Double lon = t.getGeoLocation().getLongitude();
      println(i + " USER: " + user + " wrote: " + msg + " located at " + lat + ", " + lon);

    TableRow newRow = table.addRow();
    newRow.setString("id", user);
    newRow.setDouble("latitude", lat);
    newRow.setDouble("longitude", lon);

    saveTable(table, "data2/syria_16500_5.csv");      
    } 
  }
  println("lastID= " + lastID);
}

class Timer {
  int savedTime;
  int totalTime;

  Timer (int tempTotalTime) {
    totalTime = tempTotalTime;
  }

  void start(){
    savedTime = millis();
  }

 boolean isFinished() {
    int passedTime = millis() - savedTime;
    if (passedTime > totalTime){
      return true;
    } else {
      return false;
    }
  }
}
4

1 に答える 1

1

テーブルに追加するための直接的な実装はないようです。そのため、ハックに頼る必要があります。処理中にテーブルをロードし、それに書き込み、再保存します。次のようなものです。

processing.data.Table table;
void setup() {
  File f = new File(sketchPath("") + "data2/syria_16500_5.csv");
    println(f.getAbsolutePath());
  if (!f.exists()) {
    table = new processing.data.Table();
    table.addColumn("id");
    table.addColumn("latitude");
    table.addColumn("longitude");
  } 
  else 
    table = loadTable("data2/syria_16500_5.csv", "header, csv");
  TableRow newRow = table.addRow();
  newRow.setString("id", "asad");
  newRow.setDouble("latitude", 234);
  newRow.setDouble("longitude", 2523);

  saveTable(table, "data2/syria_16500_5.csv");
}

スケッチは、最初にファイルが存在するかどうかを確認します。そうでない場合は新しいテーブルを作成し、そうでない場合は古いテーブルをヘッダーとともにロードします。これは特に安全ではないことに注意してください... 列を変更して (たとえば、テキスト エディターで) スケッチを再度実行しようとすると、例外が発生します。

于 2013-09-23T09:40:58.123 に答える