Google表格中的日期插入附加在单元格中

时间:2016-09-04 09:39:53

标签: java google-sheets google-sheets-api

要将数据写入Google电子表格,我使用以下代码。

private static void writeValuesInSpreedSheet(Sheets service, String spreadsheetId, int sheetSize) throws IOException {
    String range = "A"+(sheetSize+1)+":K"+(sheetSize+1);
    List<List<Object>> newData = new ArrayList<>();
    List<Object> rowValues = new ArrayList();
    rowValues.add(getCurentDateInESTFormat());
    rowValues.add("2");
    rowValues.add("3");
    rowValues.add("4");
    rowValues.add("5");
    rowValues.add("6");
    rowValues.add("7");
    rowValues.add("8");
    rowValues.add("9");
    rowValues.add("10");
    rowValues.add("11");
   /* List<Object> rowValues1 = new ArrayList();
    rowValues1.add("1");
    rowValues1.add("2");*/
    newData.add(rowValues);
    //newData.add(rowValues1);
   // response.setValues(newData);


    ValueRange oRange = new ValueRange();
    oRange.setRange(range); // I NEED THE NUMBER OF THE LAST ROW
    oRange.setValues(newData);
    List<ValueRange> oList = new ArrayList<>();
    oList.add(oRange);

    BatchUpdateValuesRequest oRequest = new BatchUpdateValuesRequest();
    oRequest.setValueInputOption("RAW");
    oRequest.setData(oList);

    BatchUpdateValuesResponse oResp1 = service.spreadsheets().values().batchUpdate(spreadsheetId, oRequest).execute();

    System.out.println("Response Values " +oResp1.values());

}

private static Object getCurentDateInESTFormat() {
    SimpleDateFormat sdfAmerica = new SimpleDateFormat("MM/dd/YYYY");
    sdfAmerica.setTimeZone(TimeZone.getTimeZone("America/New_York"));
    String sDateInAmerica = sdfAmerica.format(new Date());

    return sDateInAmerica;
}

在表格中,我们已经定义了相应列的日期和货币类型。

我能够编写数据,但最终会在数据中预先加载',例如 - '09/04/2016

因此我们无法将其打开为日期格式。我也附上了一个屏幕截图。

enter image description here

我们正在使用Google Sheets API V4。

我问这个问题,因为我没有找到任何与之相关的链接/解决方案。

1 个答案:

答案 0 :(得分:1)

使用ValueInputOption RAW时,您需要在serial number format中传递日期。 Apache POI库提供getExcelDate方法,可以为您处理大部分内容,但是您需要添加一天来考虑epoch used中的差异。