首页 > 解决方案 > 我在脚本属性中存储了一个对象,但它以字符串的形式返回

问题描述

我将我的简单对象(只有七个值)存储在脚本属性中,但是当我取回它时,它似乎是一个字符串。有没有一种快速的方法可以把它扔回去?如有必要,我可以将这些保存为单独的属性,但这不太整洁。

  var myObject = {
    email: range[0][1],
    sitecode: range[0][2],
    x: range[0][3],
    x: range[0][4],
    x: range[0][5],
    region: range[0][6],
    x: range[0][7] 

  }

  var userProperties = PropertiesService.getUserProperties();
  userProperties.setProperty('globals', myObject);

到目前为止一切顺利,那么我们称之为

 var userProperties = PropertiesService.getUserProperties();
  var myObject = userProperties.getProperty('globals');
  Logger.log(myObject);
  Logger.log(userProperties.getKeys());
  Logger.log(myObject.region);
  Logger.log(myObject['region']);

但得到这个

[19-05-02 13:59:22:626 PDT] {sitecode=TEST, x=x, x=x, x=x, region=North America, x=x, email=x}
[19-05-02 13:59:22:642 PDT] [globals]
[19-05-02 13:59:22:643 PDT] undefined
[19-05-02 13:59:22:643 PDT] undefined

我希望最后两个记录器行返回“北美”。事实上,他们没有对我说这是一个字符串而不是一个对象。

标签: google-apps-script

解决方案


两者都将它们的键PropertiesServiceCacheService值存储为字符串,因此当您尝试保存对象时,会存储其字符串表示形式。

一种解决方案是利用JSON.stringify()首先将对象序列化为 JSON 字符串,然后将其存储,然后在您稍后检索对象时使用JSON.parse()来取回原始对象。


推荐阅读