- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试使用 PHP 更新现有 SmartSheet 工作表中的一些单元格。添加新行没问题,但我无法获取正确的 JSON 进行更新。
此时我的代码:
$ch = curl_init("https://api.smartsheet.com/1.1/sheet/1234567890/rows/");
$header = array("Authorization: Bearer xxxxxxxxxxx",
"Content-Type: application/json",
"Assume-User: xxxx%40xxxx.com");
$name = 'MyName';
$fields = '{"rowNumber":1, "columnId": 1234567890, "value": "'.$name.'", "displayValue": "'.$name.'"}';
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($ch, CURLOPT_POSTFIELDS, $fields);
curl_setopt($ch, CURLOPT_POST, 1);
$result = curl_exec($ch);
这导致:
"{"errorCode":1008,"message":"Unable to parse request. The following error occurred: Unknown attribute \"columnId\" found at line 1, column 45"}"
我尝试了很多选项,但无法通过 API 文档解决这个问题,也找不到任何其他执行相同操作的 PHP 示例。有人知道如何连续更新一个特定的单元格吗?
最佳答案
可以找到更新行的 API 文档 here .它给出了以下在命令行中使用 curl 的示例:
curl https://api.smartsheet.com/1.1/row/{rowId}/cells \
-H "Authorization: Bearer ACCESS_TOKEN" \
-H "Content-Type: application/json" \
-X PUT \
-d '[ {"columnId": 3738748463671172, "value": "Revision 2"}, {"columnId": 5427598323935108, "value": "On Time", "strict": false} ]'
我们需要更改您的 PHP 示例以按照上述文档发送数据。因此,需要更改 php 示例中的以下项目:
[{"columnId": 13214124123213, "value": "my new text1"}, {"columnId": 1231231241238, "value": "my new text2"}]
考虑到这一点,我们可以将代码更改为以下内容:
<?php
$ch = curl_init("https://api.smartsheet.com/1.1/row/4407426335172484/cells");
$header = array("Authorization: Bearer 1238123lkjafasdilfasflkj",
"Content-Type: application/json",
"Assume-User: some%40email.com");
$name = 'MyName';
$fields = '[{"columnId": 4431344890603396, "value": "'.$name.'", "displayValue": "'.$name.'"}]';
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
curl_setopt($ch, CURLOPT_POSTFIELDS, $fields);
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "PUT");
$result = curl_exec($ch);
print_r($result);
?>
您可能想知道 rowId 和 columnId 从何而来。这两个ID需要通过获取sheet的方式从API中获取。这可以使用 Curl 来完成,Advanced Rest Client for Chrome或通过 PHP。 PHP 示例如下:
<?php
$ch = curl_init("https://api.smartsheet.com/1.1/sheet/1837937135511428");
$header = array("Authorization: Bearer 123l1k2j321lkjasdfa",
"Content-Type: application/json",
"Assume-User: some%40email.com");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
$result = curl_exec($ch);
print_r($result);
?>
此请求将输出如下内容并列出列 ID 和行 ID。
{
"id":1837937135511428,
"name":"test",
"version":3,
"columns":[
{
"id":4431344890603396,
"index":0,
"title":"Primary Column",
"type":"TEXT_NUMBER",
"primary":true,
"width":150
},
{
"id":8934944517973892,
"index":1,
"title":"Column2",
"type":"TEXT_NUMBER",
"width":150
},
{
"id":138851495765892,
"index":2,
"title":"Column3",
"type":"TEXT_NUMBER",
"width":150
},
{
"id":4642451123136388,
"index":3,
"title":"Column4",
"type":"TEXT_NUMBER",
"width":150
},
{
"id":2390651309451140,
"index":4,
"title":"Column5",
"type":"TEXT_NUMBER",
"width":150
},
{
"id":6894250936821636,
"index":5,
"title":"Column6",
"type":"TEXT_NUMBER",
"width":150
}
],
"rows":[
{
"id":4407426335172484,
"rowNumber":1,
"cells":[
{
"columnId":4431344890603396,
"type":"TEXT_NUMBER",
"value":"My Name",
"displayValue":"My Name"
},
{
"columnId":8934944517973892,
"type":"TEXT_NUMBER",
"value":"test",
"displayValue":"test"
}
],
"expanded":true,
"createdAt":"2014-06-23T09:32:02-07:00",
"modifiedAt":"2014-06-23T09:48:55-07:00"
}
],
"accessLevel":"OWNER",
"ganttEnabled":false,
"dependenciesEnabled":false,
"permalink":"https://app.smartsheet.com/b/home?lx=v75AYzRUICSXF_2oV6V_LA",
"workspace":{
"id":6724185599829892,
"name":"Test"
},
"createdAt":"2014-06-23T09:28:58-07:00",
"modifiedAt":"2014-06-23T09:48:55-07:00"
}
关于php - 更新智能表中的单元格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24365644/
是否可以有DropShadowEffect渲染阴影时忽略某些颜色?有某种蒙版(颜色选择性)阴影? 我的问题是什么阴影可以分配给整个视觉元素(图形)。它看起来像这样: 而且我要 注意没有阴影的网格线(除
It's difficult to tell what is being asked here. This question is ambiguous, vague, incomplete, over
有时,当我尝试使用 maven mvn clean install jetty:run 运行我的项目时,它会返回一个错误消息:“地址已在使用中”。 我正在使用 Intellij IDEA 14。 你能
我见过几个数据库缓存引擎,它们都非常愚蠢(即:将此查询缓存 X 分钟)并要求您在 之后手动删除整个缓存存储库>INSERT/UPDATE/DELETE 查询已执行。 大约 2 或 3 年前,我为我正在
我正在寻找例程或寻找错误容忍字符串比较的方法。 比方说,我们有测试字符串 Čakánka - 是的,它包含 CE 字符。 现在,我想接受以下任何字符串作为 OK: 恰坎卡 cákanká ÇaKaNK
大家好 我在 windows xp 系统上使用智能 gwt 2.3 专业版和 Mozilla。 我在上面做了测试应用程序,它运行成功。 现在我想为此应用程序使用开发人员控制台。 我的gwt.xml 编
说,我有 member this.Test (x: 'a) = printfn "generic" 1 member this.Test (x:
我正在努力寻找有关如何将应用程序部署到索尼智能 watch 的任何文档或教程(我正在尝试部署由索尼编写的开源“Eight Puzzle”应用程序,我已将其导入到 Eclipse 中。我有一个三星 S3
我正在寻找一个类似于标准格式化程序的智能 Java 字符串格式化程序: StringBuffer buffer = new StringBuffer(); Formatter form
我有一个智能 JScrollPane,但与其他所有解决方案不同,我想知道如果滚动 Pane 不在底部并且文本是否可以跟随(向上滚动)查看的组件(JTextArea)缓冲区已满。包含功能齐全的代码片段。
我有一个包含 18 个类(class)的项目。它们正在工作线程保存(已检查),没有递归调用,也没有任何复杂的计算。 但是我的IDEA总是说几个小时后 There is not enough memor
我想使用 Smart XLS 库在 C# 中处理 excel 文件(特别是因为它可以生成图表,而且它的价格明显低于 Aspose Cells),但我找不到任何好的例子。我只想知道如何创建和修改图表,有
我正在寻找一个完整的 java 日期管理库,它可以让我理解像这样的字符串: 明天中午 => 2011-10-20 12:00 今天下午 4 点 => 2011-10-20 16:00 等... 但如果
我想打开手机中的文件,通过 watch 中的 Action ... 问题是: Intent intent2 = new Intent(); intent2.setAction(android.cont
我想编译 Sony 为他的 SmartWatch 提供的示例。我按照此 page 中的说明进行操作.但是当我添加 SmartExtensionUtils 项目时,我看到了很多错误,例如:com.son
我有一个 SQL 表:名称、位置、体积 名称为字符串类型 位置是两个 float 类型的字段(纬度和经度) int 类型的体积 我想运行一个 SQL 查询,该查询将对特定范围内的所有位置进行分组并对所
我需要找到当我点击某物时调用的方法。项目很大,自己找会花不少时间。有什么办法可以做到吗?我正在使用 Android Studio,是的,这是我有史以来第一次使用其他人的项目。 最佳答案 我是怎么做到的
我在我的 iMac 上安装了智能 cvs,我已经从 cvs 更新了应用程序。然后我对我的代码和核心数据做了一些更改(核心数据更改是:从核心数据实体中删除一些属性),然后我尝试将更改提交给 cvs,但我
在我的 Java 项目中,我有一个类 Person,它存在于两个具有相同包名 (com.example.beans) 的不同 jar 中。 问题是这个类在jar1中是这样定义的: class Pers
已关闭。此问题旨在寻求有关书籍、工具、软件库等的建议。不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以
我是一名优秀的程序员,十分优秀!