1

まず、似たような質問がありますが、似ているだけで同じではありません:)

このスクリプトは、Google コンタクト ->コンタクト サービスをスプレッドシートにインポートします。

function onOpen()
{
  var menuItems = [{name: "Gmail Contact Import", functionName: "getContacts"}];
  SpreadsheetApp.getActiveSpreadsheet().addMenu("import", menuItems);
}

function getContacts()
{
  var groupName = "MyGroup";
  var contacts;
  var sheet = SpreadsheetApp.getActiveSheet();

  if (groupName) {
    var contactGroup = ContactsApp.findContactGroup(groupName);

    if (contactGroup) {
      contacts = contactGroup.getContacts();
    }
  } 
  else {
    contacts = ContactsApp.getAllContacts();
  }

  if (!contacts) {
    Browser.msgBox("no contacts found!");
    return;
  }  

  sheet.clear();

  sheet.getRange("A1").setValue("forename");
  sheet.getRange("B1").setValue("lastname");
  sheet.getRange("C1").setValue("private email");
  sheet.getRange("D1").setValue(groupName + " email");
  sheet.getRange("E1").setValue("phone");
  sheet.getRange("F1").setValue("mobile");
  sheet.getRange("G1").setValue("street");
  sheet.getRange("H1").setValue("zip");
  sheet.getRange("I1").setValue("city");
  sheet.getRange("J1").setValue("group");
  sheet.getRange("K1").setValue("date1");
  sheet.getRange("L1").setValue("date2");
  sheet.getRange("M1").setValue("date3");
  sheet.getRange("N1").setValue("date4");

  for ( var i = 0; i < contacts.length; i++) {
    var addressArray = new Array();
    addressArray = contacts[i].getAddresses(ContactsApp.Field.HOME_ADDRESS);
    var addressArrayLength = addressArray.length;    
    for ( var ii = 0; ii < addressArrayLength; ii++ ) {
      var address = addressArray[ii].getAddress();
      var addressSplit = address.split(/\r\n|\r|\n/);
      var street = addressSplit[0];
      var city = addressSplit[1].split(" ")[0];
      var zip = addressSplit[1].split(" ")[1];
    }
    var homePhone = contacts[i].getHomePhone().replace("0049-","0").toString();
    var mobilePhone = contacts[i].getMobilePhone().replace("0049-","0").toString();
    var fireMail = ""
    var privateMail = "";
    var mailArray = new Array();
    mailArray = contacts[i].getEmails(ContactsApp.Field.HOME_EMAIL);
    var mailArrayLength = mailArray.length;    
    for ( var ii = 0; ii < mailArrayLength; ii++ ) {
      privateMail = contacts[i].getEmails(ContactsApp.Field.HOME_EMAIL)[ii].getAddress();
    }

    if (!privateMail)
    {
      mailArray = contacts[i].getEmails(ContactsApp.Field.WORK_EMAIL);
      mailArrayLength = mailArray.length;

      for ( var ii = 0; ii < mailArrayLength; ii++ ) {
        privateMail = contacts[i].getEmails(ContactsApp.Field.WORK_EMAIL)[ii].getAddress();
      }
    }

    mailArray = contacts[i].getEmails(groupName);
    mailArrayLength = mailArray.length;

    for ( var ii = 0; ii < mailArrayLength; ii++ ) {
      fireMail = contacts[i].getEmails(groupName)[ii].getAddress();
    }

    sheet.getRange(1*i+2, 1, 1, 1).setValue(contacts[i].getGivenName());
    sheet.getRange(1*i+2, 2, 1, 1).setValue(contacts[i].getFamilyName());
    sheet.getRange(1*i+2, 3, 1, 1).setValue(privateMail);
    sheet.getRange(1*i+2, 4, 1, 1).setValue(fireMail);
    sheet.getRange(1*i+2, 5, 1, 1).setValue(homePhone);
    sheet.getRange(1*i+2, 6, 1, 1).setValue(mobilePhone);
    sheet.getRange(1*i+2, 7, 1, 1).setValue(street);
    sheet.getRange(1*i+2, 8, 1, 1).setValue(zip);
    sheet.getRange(1*i+2, 9, 1, 1).setValue(city);

    var groups = contacts[i].getContactGroups();

    for ( var j = 0; j < groups.length; j++) {
      var name = groups[j].getName();
      switch (name) {
        case "group1":
          sheet.getRange(1*i+2, 10, 1, 1).setValue(1);
          break;
        case "group2":
          sheet.getRange(1*i+2, 10, 1, 1).setValue(2);
          break;
        case "group3":
          sheet.getRange(1*i+2, 10, 1, 1).setValue(3);
          break;
        case "group4":
          sheet.getRange(1*i+2, 10, 1, 1).setValue(4);
          break;
        case "group5":
          sheet.getRange(1*i+2, 10, 1, 1).setValue(5);
          break;
        default:
          break;
      }

      if (name.indexOf("datetrigger1") > -1)
      {
        var dateArray = contacts[i].getDates("date1");
        var dateArrayLength = dateArray.length;        
        for ( var ii = 0; ii < dateArrayLength; ii++ ) {
          var date = contacts[i].getDates("date1")[ii];
          var day = date.getDay();
          var month = date.getMonth();
          var year = date.getYear();
          sheet.getRange(1*i+2, 11, 1, 1).setValue(day.toString() + "." + month.toString() + "." + year.toString());
        }
        sheet.getRange(1*i+2, 11, 1, 1).setBackgroundColor('green');
      }

      if (name.indexOf("datetrigger2") > -1)
      {
        var dateArray = contacts[i].getDates("date2");
        var dateArrayLength = dateArray.length;        
        for ( var ii = 0; ii < dateArrayLength; ii++ ) {
          var date = contacts[i].getDates("date2")[ii];
          var day = date.getDay();
          var month = date.getMonth();
          var year = date.getYear();
          sheet.getRange(1*i+2, 12, 1, 1).setValue(day.toString() + "." + month.toString() + "." + year.toString());
        }
        sheet.getRange(1*i+2, 12, 1, 1).setBackgroundColor('green');
      }

      if (name.indexOf("datetrigger3") > -1)
      {
        var dateArray = contacts[i].getDates("date3");
        var dateArrayLength = dateArray.length;        
        for ( var ii = 0; ii < dateArrayLength; ii++ ) {
          var date = contacts[i].getDates("date3")[ii];
          var day = date.getDay();
          var month = date.getMonth();
          var year = date.getYear();
          sheet.getRange(1*i+2, 13, 1, 1).setValue(day.toString() + "." + month.toString() + "." + year.toString());
        }
        sheet.getRange(1*i+2, 13, 1, 1).setBackgroundColor('green');
      }

      if (name.indexOf("datetrigger4") > -1)
      {
        var dateArray = contacts[i].getDates("date4");
        var dateArrayLength = dateArray.length;
        if (dateArrayLength > 0) {
          for ( var ii = 0; ii < dateArrayLength; ii++ ) {
            var date = contacts[i].getDates("date4")[ii];
            var day = date.getDay();
            var month = date.getMonth();
            var year = date.getYear();
            sheet.getRange(1*i+2, 14, 1, 1).setValue(day.toString() + "." + month.toString() + "." + year.toString());
          }
          sheet.getRange(1*i+2, 14, 1, 1).setBackgroundColor('green');
        }
      }
    }
  }

  Browser.msgBox(contacts.length + " contacts imported.");
}

正常に動作しますが、「xy 連絡先がインポートされました」というメッセージの後に、次のエラー メッセージが表示されます。

シリアライズ継続時の予期しない例外

何が悪いのかわかりません。

更新 2012 年 7 月 26 日:

追加のエラーがあります:

Dienst-Fehler: ContactsApp: 一時的な問題 - 後でもう一度試して、バッチ操作の使用を検討してください。ユーザーはクォータを超えています。(ザイレ96)

それはこの行についてです:var groups = contacts[i].getContactGroups();

後でもう一度試しました...エラーがまだ来ます。常にリストに結果が表示されます。エラーは、ループのさまざまな反復の後に発生します。

更新 2012 年 7 月 27 日:

Utilities.sleep(2000);の後に追加しましたvar groups = contacts[i].getContactGroups();。これで十分です。連絡先が少ない…

4

1 に答える 1

4

このようなエラーメッセージが頻繁に表示されます。これが私がすることです:

  1. msgBox 呼び出しの結果である可能性があります。Browser.msgBox("..."); を置き換えます。Logger.log("..."); を使用 その後、スクリプト エディター > [表示] > [ログ...] で結果を表示できます。

  2. スクリプトは、スプレッドシート UI でトリガーできない承認を必要とする場合があります。スクリプト エディタ > [実行] > [getContacts] でスクリプトを実行します。

お役に立てれば。

2012 年 7 月 27 日の更新:

割り当てエラーに関する後の質問への回答:

Google にはサービス拒否に対する防御層がいくつかありますが、そのうちの 1 つはユーザーの割り当てです。GAS サービス クォータの一部はhttps://script.google.com/dashboard ([クォータ制限] タブに移動) にリストされていますが、すべてが公開されているわけではありません。たとえば、エラーはそこにリストされているクォータに対するものではありません。

もう 1 つのレイヤーはレート制限です。短期間 (たとえば 1 秒) に API 呼び出しを何度も行うと、しきい値に達する可能性があります。これは、私が考えていることです。指数バックオフを使用することをお勧めします。Google によると、指数バックオフで最大 5 回の再試行を実行し、約 1、2、4、8、16 秒の遅延で再試行し、合計で約 32 秒後に回復不能なエラーであきらめる必要があります。参照: https://developers.google.com/google-apps/documents-list/#implementing_exponential_backoff

指数バックオフを自動的に行うために使用する GASRetry ライブラリ関数があります。ここで管理しており、公開ライブラリ プロジェクト キーとして利用できます: MGJu3PS2ZYnANtJ9kyn2vnlLDhaBgl_dE も

コード行を例にとると、次のように GASRetry 呼び出しでラップします。

//var groups = contacts[i].getContactGroups();
var groups = GASRetry.call(function(){contacts[i].getContactGroups()});

これにより、短期的なレート制限が解消されます。行き方を教えてください。

于 2012-07-24T22:58:10.757 に答える