Google表格C#没有返回所有表格

时间:2016-01-20 01:49:25

标签: c# google-api google-sheets google-spreadsheet-api service-accounts

我已经实施了Google服务帐户,并将其作为授权用户添加到工作表中。

接下来,我使用以下代码访问工作表Feed:

const string gUser = "SVC-ACCOUNT@developer.gserviceaccount.com";
const string certFile = "CERTFILE.p12";
    static void Main(string[] args) {
        var certificate = new X509Certificate2(certFile, "notasecret", X509KeyStorageFlags.Exportable);

        var serviceAccountCredentialInitializer = new ServiceAccountCredential.Initializer(gUser) {
            Scopes = new[] { "https://spreadsheets.google.com/feeds/" }
        }.FromCertificate(certificate);


        var credential = new ServiceAccountCredential(serviceAccountCredentialInitializer);
        if (!credential.RequestAccessTokenAsync(System.Threading.CancellationToken.None).Result)
            return;

        var requestFactory = new GDataRequestFactory(null);
        requestFactory.CustomHeaders.Add("Authorization: Bearer " + credential.Token.AccessToken);
        var service = new SpreadsheetsService("MY-SHEETS-SVC") { RequestFactory = requestFactory };

        SpreadsheetQuery query = new SpreadsheetQuery();
        var sheetFeed = service.Query(query);

        Console.WriteLine("Spreadsheet list:");
        foreach (var sheet in sheetFeed.Entries) {
            Console.WriteLine("\t--" + sheet.Title.Text);
        }
        Console.ReadLine();
    }

但是,尽管授予了服务帐户编辑权限,但它不会返回任何工作表。我已经将服务帐户添加到Google Apps安全组,但结果没有变化。在过去创建帐户(相同的应用程序域等)并在共享设置中授予它编辑权限是所有需要的。 API是否已更改为仅需要OAUTH,或者某个地方是否存在我丢失的设置?

1 个答案:

答案 0 :(得分:0)

我的应用领域正在发生变化,目前正在迁移中。在新帐户下添加了一个表单,它立即出现。