sheets - Google Sheet API V4(Java) anexa la fecha en las celdas
php google spreadsheet api (2)
He intentado agregar la fecha en las celdas pero la hoja almacena automáticamente el valor en la cadena con comillas simples ( ''
). Para Store value in date, también intentamos agregar userEnteredFormat
pero no funcionó para nosotros.
A continuación se encuentran las solicitudes adjuntas.
{
requests = [{
appendCells = {
fields = userEnteredValue,
userEnteredFormat.numberFormat,
rows = [{
values = [{
userEnteredValue = {
numberValue = 10.0
}
}, {
userEnteredValue = {
stringValue = Sample String
}
}, {
userEnteredFormat = {
numberFormat = {
type = DATE
}
},
userEnteredValue = {
stringValue = 2015 - 07 - 13
}
}, {
userEnteredValue = {
boolValue = true
}
}, {
userEnteredFormat = {
numberFormat = {
type = DATE
}
},
userEnteredValue = {
stringValue = 2015 - 07 - 13
}
}]
}],
sheetId = abc
}
}]}
Código de ejemplo para agregar celdas de fecha única en una hoja
package org.pentaho.googlesheets.api;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import org.pentaho.di.i18n.BaseMessages;
import org.pentaho.pdi.steps.googlesheets.GoogleSheetsOutputStepMeta;
import com.google.api.client.auth.oauth2.Credential;
import com.google.api.client.googleapis.auth.oauth2.GoogleCredential;
import com.google.api.client.googleapis.javanet.GoogleNetHttpTransport;
import com.google.api.client.http.HttpTransport;
import com.google.api.client.json.JsonFactory;
import com.google.api.client.json.gson.GsonFactory;
import com.google.api.services.drive.DriveScopes;
import com.google.api.services.sheets.v4.Sheets;
import com.google.api.services.sheets.v4.SheetsScopes;
import com.google.api.services.sheets.v4.model.AppendCellsRequest;
import com.google.api.services.sheets.v4.model.BatchUpdateSpreadsheetRequest;
import com.google.api.services.sheets.v4.model.BatchUpdateSpreadsheetResponse;
import com.google.api.services.sheets.v4.model.CellData;
import com.google.api.services.sheets.v4.model.CellFormat;
import com.google.api.services.sheets.v4.model.ExtendedValue;
import com.google.api.services.sheets.v4.model.NumberFormat;
import com.google.api.services.sheets.v4.model.Request;
import com.google.api.services.sheets.v4.model.RowData;
public class DateIssueSample {
static String APPLICATION_NAME ;
static JsonFactory JSON_FACTORY;
static HttpTransport HTTP_TRANSPORT;
static List<String> SPREADSHEET_SCOPES ;
static List<String> DRIVE_SCOPES ;
static Sheets service;
static String email = "[email protected]";
static String pkey ="E://P12Key//My Project-834a8d37d247.p12";
public static Credential authorize(List<String> SCOPES ) throws Exception {
GoogleCredential credential = new GoogleCredential.Builder()
.setTransport(HTTP_TRANSPORT)
.setJsonFactory(JSON_FACTORY)
.setServiceAccountId(email)
.setServiceAccountScopes(SCOPES)
.setServiceAccountPrivateKeyFromP12File(new java.io.File(pkey))
.build();
credential.refreshToken();
return credential;
}
public static Sheets getSheetsService() throws Exception {
Credential credential = authorize(SPREADSHEET_SCOPES);
return new Sheets.Builder(HTTP_TRANSPORT, JSON_FACTORY, credential)
.setApplicationName(APPLICATION_NAME)
.build();
}
public static void main(String[] args) throws Exception {
APPLICATION_NAME = "PDI";
JSON_FACTORY =new GsonFactory();
SPREADSHEET_SCOPES =Arrays.asList(SheetsScopes.SPREADSHEETS);
DRIVE_SCOPES=Arrays.asList(DriveScopes.DRIVE_METADATA_READONLY);
HTTP_TRANSPORT = GoogleNetHttpTransport.newTrustedTransport();
service = getSheetsService();
String spreadSheetID= "abc";
Integer sheetID = 123;
String DateValue = "2015-07-13";
List<RowData> rowData = new ArrayList<RowData>();
List<CellData> cellData = new ArrayList<CellData>();
CellData cell = new CellData();
cell.setUserEnteredValue(new ExtendedValue().setStringValue(DateValue));
cell.setUserEnteredFormat(new CellFormat().setNumberFormat(new NumberFormat().setType("DATE")));
cellData.add(cell);
rowData.add(new RowData().setValues(cellData));
BatchUpdateSpreadsheetRequest batchRequests = new BatchUpdateSpreadsheetRequest();
BatchUpdateSpreadsheetResponse response;
List<Request> requests = new ArrayList<Request>();
AppendCellsRequest appendCellReq = new AppendCellsRequest();
appendCellReq.setSheetId( sheetID);
appendCellReq.setRows( rowData );
appendCellReq.setFields("userEnteredValue,userEnteredFormat.numberFormat");
requests = new ArrayList<Request>();
requests.add( new Request().setAppendCells(appendCellReq));
batchRequests = new BatchUpdateSpreadsheetRequest();
batchRequests.setRequests( requests );
response= service.spreadsheets().batchUpdate(spreadSheetID, batchRequests).execute();
System.out.println("Request /n/n");
System.out.println(batchRequests.toPrettyString());
System.out.println("/n/nResponse /n/n");
System.out.println(response.toPrettyString());
}
}
SpreadSheet , código de ejemplo para el valor de fecha única
Consulte la explicación de la guía de introducción sobre cómo funciona la API con datetimes.
Las fechas en Hojas son números, no cadenas. (Esto le permite, por ejemplo, hacer aritmética sobre ellos).
Si usa la colección de ''valores'' , hay ganchos para traducir de cadena a fecha y viceversa (usando diferentes ValueInputOptions o ValueRenderOptions .
Lamentablemente, todavía no hay un método de Append en la colección de valores. Por lo tanto, para agregar celdas fácilmente después de los datos existentes, debe usar spreadsheets.batchUpdate, y eso es solo el DOM sin procesar de la hoja de cálculo. Por lo tanto, por ahora, deberá ingresar las fechas como números de serie (con formato de fecha), como se describe en el primer enlace.
La razón por la que las cadenas se agregan con una sola comilla es porque le está diciendo a la API que desea agregar una cadena, por lo que se agrega un prefijo para evitar que Sheets analice accidentalmente el valor en una fecha.
Para proporcionar un ejemplo de lo que significa la respuesta de Sam, si solo desea crear un valor de fecha usando AppendCellsRequest
, puede crear la celda de esta manera:
CellData cell = new CellData();
cell.setUserEnteredValue(new ExtendedValue().setNumberValue(42198.0));
cell.setUserEnteredFormat(
new CellFormat().setNumberFormat(new NumberFormat().setType("DATE")));
Aquí 42198 es el número de días entre el 30 de diciembre de 1899 y el 13 de julio de 2015.