Google Tasks API を使用して、タスクのタイトル、タスクのメモ、タスクの期日などの値を返しています。
期日 ( RFC 3339 として保存) を文字列として出力しようとすると、 java.lang.IllegalArgumentException
.
SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'")
この変換を行うために使用しようとしています。
私の推測では、それSimpleDateFormat
は進むべき道ではありませんが、私が試みた他のすべての変換は失敗しました。私は Joda を使用することにオープンですISODateFormat
が、それでもうまくいきませんでした。関連するコードのスニペットを含めました。
私のタスク(コールアイテム)クラスの定義は次のとおりです。
import com.google.api.client.util.DateTime;
public class Item {
Long id;
String title;
String description;
String extId1;
Integer status;
DateTime dateDue;
DateTime dateLastEdit;
DateTime dateCompleted;
Item parent;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getDescription() {
return description;
}
public void setNotes(String description) {
this.description = description;
}
public String getExtId1() {
return extId1;
}
public void setExtId1(String extId1) {
this.extId1 = extId1;
}
public Integer getStatus() {
return status;
}
public void setStatus(Integer status) {
this.status = status;
}
public DateTime getDateDue() {
return dateDue;
}
public void setDateDue(DateTime dateDue) {
this.dateDue = dateDue;
}
public DateTime getDateLastEdit() {
return dateLastEdit;
}
public void setDateLastEdit(DateTime dateLastEdit) {
this.dateLastEdit = dateLastEdit;
}
public DateTime getDateCompleted() {
return dateCompleted;
}
public void setDateCompleted(DateTime dateCompleted) {
this.dateCompleted = dateCompleted;
}
public Item getParent() {
return parent;
}
public void setParent(Item parent) {
this.parent = parent;
}
}
これがうまくいかないことを確認するために、返された日付を出力しようとする doInBackground メソッドを示します。
@Override
protected List<Item> doInBackground(Void... arg0) {
List<Item> itemList = new ArrayList<Item>();
DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss.SSS'Z'");
Log.v(TAG, "Start doInBackground...");
try {
List<String> result = new ArrayList<String>();
com.google.api.services.tasks.Tasks.TasksOperations.List listRequest = service.tasks().list("@default");
listRequest.setFields("items/title,items/notes,items/due");
List<Task> tasks = listRequest.execute().getItems();
if (tasks != null) {
for (Task task : tasks) {
result.add(task.getTitle());
Item item = new Item();
item.setTitle(task.getTitle());
item.setNotes(task.getNotes());
DateTime due = task.getDue();
item.setDateDue(due);
Log.v(TAG, "Due date string: " + formatter.format(due));
itemList.add(item);
}
} else {
Log.v(TAG, "End doInBackground with no tasks");
result.add("No tasks.");
}
Log.v(TAG, "End doInBackground with tasks received");
return itemList;
} catch (IOException e) {
Log.v(TAG, "End doInBackground with IOException...");
tasksSample.handleGoogleException(e);
Item item = new Item();
item.setTitle(e.getMessage());
itemList.add(item);
return itemList;
//return Collections.singletonList(e.getMessage());
} catch (Exception e2) {
Log.v(TAG, "End doInBackground with generic exception...");
e2.printStackTrace();
Item item = new Item();
item.setTitle(e2.getMessage());
itemList.add(item);
return itemList;
} finally {
tasksSample.onRequestCompleted();
}
}
編集:
リクエストに応じて、スタック トレースを次に示します。
[java.text.DateFormat.format(DateFormat.java:365)、java.text.Format.format(Format.java:93)、com.google.api.services.samples.tasks.android.AsyncLoadTasks.doInBackground(AsyncLoadTasks) .java:78)、com.google.api.services.samples.tasks.android.AsyncLoadTasks.doInBackground(AsyncLoadTasks.java:1)、android.os.AsyncTask$2.call(AsyncTask.java:264)、java.util .concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)、java.util.concurrent.FutureTask.run(FutureTask.java:137)、android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:208) 、java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)、java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)、java.lang.Thread.run(Thread.java:856) )]
タスク リソースは次のとおりです。
{"期限":"2012-07-04T00:00:00.000Z","メモ":"メモ1","タイトル":"テスト1"}