【问题标题】:java google spreadsheet get cell colorjava google电子表格获取单元格颜色
【发布时间】:2017-05-29 14:35:03
【问题描述】:

我正在使用 Google Sheets API v4 从我的谷歌驱动器中获取电子表格 (excel)。遵循本教程https://developers.google.com/sheets/api/quickstart/java 我实现了我的第一个目标,即将所有数据作为 Json 检索到我的独立 Java 应用程序中。 它运行良好,我可以很好地将其保存到我的数据库中。 现在我还需要获取单元格颜色和单元格提示(如果存在)。但直到现在我一直在努力在网络上没有任何成功。我需要在没有 javascript 的情况下做到这一点。 下面是我的代码: 我将所有值放入名为 values 的数组数组中,但这里只检索单元格的值,也没有背景颜色,也没有单元格提示。

        Sheets service = getSheetsService();    
        String spreadsheetId = "xxxx-xxxxx-xxxxxx-xxxxx";
        String range = "A1:ce604";

        service.spreadsheets().get(spreadsheetId);

        ValueRange response = service.spreadsheets().values().get(spreadsheetId, range).execute(); 

        List<List<Object>> values = response.getValues();

        spreedSheetService.stroreDatas(values);

有人知道是否可以这样做吗?

【问题讨论】:

    标签: java excel google-apps-script google-sheets


    【解决方案1】:

    您可以使用getBackground() 返回范围内左上角单元格的背景颜色(即'#ffffff')。

    var ss = SpreadsheetApp.getActiveSpreadsheet();
    var sheet = ss.getSheets()[0];
    
    var cell = sheet.getRange("B5");
    Logger.log(cell.getBackground());
    

    getBackgrounds() 返回范围内单元格的背景颜色(即'#ffffff')。

    var ss = SpreadsheetApp.getActiveSpreadsheet();
    var sheet = ss.getSheets()[0];
    
    var range = sheet.getRange("B5:C6");
    var bgColors = range.getBackgrounds();
    for (var i in bgColors) {
      for (var j in bgColors[i]) {
        Logger.log(bgColors[i][j]);
      }
    }
    

    希望这会有所帮助!

    【讨论】:

    • 初始请求是使用远程 Java API 而不是本地 javascript
    猜你喜欢
    • 1970-01-01
    • 2017-09-14
    • 2014-07-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多