需要授权
使用您定义的过滤条件和参数查询搜索流量数据。该方法会返回按您定义的行键(维度)分组的零行或多行。您必须定义一个包含一天或多天的日期范围。
如果日期是其中一个维度,则结果列表中会省略没有数据的任何日期。如需了解哪些日期有数据,请针对感兴趣的日期范围发出按日期分组且不含过滤条件的查询。
结果按点击次数降序排序。如果两行具有相同的点击次数,则系统会以任意方式对它们进行排序。
如需调用此方法,请参阅 python 示例。
该 API 受 Search Console 内部限制的限制,不能保证返回所有数据行,而是返回热门数据行。
POST https://www.googleapis.com/webmasters/v3/sites/https%3A%2F%2Fwww.example.com%2F/searchAnalytics/query?key={MY_API_KEY} { "startDate": "2015-04-01", "endDate": "2015-05-01", "dimensions": ["country","device"] }
请求
HTTP 请求
POST https://www.googleapis.com/webmasters/v3/sites/siteUrl/searchAnalytics/query
参数
参数名称 | 值 | 说明 |
---|---|---|
路径参数 | ||
siteUrl |
string |
Search Console 中定义的资源网址。示例:http://www.example.com/ (对于网址前缀资源)或 sc-domain:example.com (对于网域资源)
|
授权
此请求需要获得以下至少一个范围的授权(详细了解身份验证和授权)。
范围 |
---|
https://www.googleapis.com/auth/webmasters.readonly |
https://www.googleapis.com/auth/webmasters |
请求正文
在请求正文中,请按以下结构提供数据:
{ "startDate": string, "endDate": string, "dimensions": [ string ], "type": string, "dimensionFilterGroups": [ { "groupType": string, "filters": [ { "dimension": string, "operator": string, "expression": string } ] } ], "aggregationType": string, "rowLimit": integer, "startRow": integer }
属性名称 | 值 | 说明 | 备注 |
---|---|---|---|
startDate |
string |
[必需] 所请求日期范围的开始日期,采用 YYYY-MM-DD 格式,采用美国太平洋时间 (UTC - 7:00/8:00)。不得晚于结束日期。该范围包含此值。 | |
endDate |
string |
[必填] 所请求日期范围的结束日期,采用 YYYY-MM-DD 格式,采用巴西时间 (UTC - 7:00/8:00)。不得早于开始日期。该范围包含此值。 | |
dimensions[] |
list |
[可选] 零个或多个用于对结果进行分组的维度。结果会按您提供这些维度的顺序进行分组。您可以在 dimensionFilterGroups[].filters[].dimension 中使用任何维度名称,以及“日期”。系统会合并这些分组维度值,为每个结果行创建一个唯一键。如果未指定维度,则所有值都将合并到一行。您可以按的维度数量没有限制,但不能按同一维度进行两次分组。示例:[country, device] | |
searchType |
string |
已弃用,请改用 type
|
|
type |
string |
[可选] 将结果过滤为以下类型:
|
|
dimensionFilterGroups[] |
list |
[可选] 要应用于维度分组值的一组或多组过滤条件。所有过滤组都必须匹配,系统才会在响应中返回相应行。在单个过滤条件组中,您可以指定是必须满足所有过滤条件,还是至少满足一个过滤条件。 | |
dimensionFilterGroups[].groupType |
string |
此组中的所有过滤器是否都必须返回 true(“与”),还是必须有一个或多个过滤器返回 true(尚不受支持)。
可接受的值包括:
|
|
dimensionFilterGroups[].filters[] |
list |
[可选] 要针对行进行测试的零个或多个过滤条件。每个过滤条件都由维度名称、运算符和值组成。长度上限为 4096 个字符。示例:country equals FRA query contains mobile use device notContains tablet |
|
dimensionFilterGroups[].filters[].dimension |
string |
此过滤条件适用的维度。您可以按此处列出的任何维度进行过滤,即使您并未按该维度进行分组也是如此。
可接受的值包括:
|
|
dimensionFilterGroups[].filters[].operator |
string |
[可选] 指定的值必须与行中的维度值如何匹配(或不匹配)。
可接受的值: |
|
dimensionFilterGroups[].filters[].expression |
string |
要匹配或排除的过滤条件的值(具体取决于运算符)。 | |
aggregationType |
string |
[可选] 数据的汇总方式。如果按资源汇总,系统会汇总同一资源的所有数据;如果按网页汇总,系统会按规范 URI 汇总所有数据。如果要按网页进行过滤或分组,请选择“自动”;否则,可以按资源或按网页汇总数据,具体取决于您希望数据的计算方式;请参阅帮助文档,了解按网站计算数据与按网页计算数据的不同之处。 注意:如果您按网页进行分组或过滤,则无法按资源进行汇总。 如果您指定 auto 以外的任何值,则结果中的汇总类型将与请求的类型匹配,如果您请求无效类型,则会收到错误。如果请求的类型无效,API 绝不会更改您的汇总类型。 可接受的值包括:
|
|
rowLimit |
integer |
[可选;有效范围为 1-25,000;默认值为 1,000] 要返回的行数上限。如需分页浏览结果,请使用 startRow 偏移量。 |
|
startRow |
integer |
[可选;默认值为 0] 响应中第一行的索引(从零开始)。必须为非负数。如果 startRow 超过查询的结果数,则响应将是成功响应,且行数为零。 |
|
dataState |
string |
[可选] 如果为“all”(不区分大小写),则数据将包含新鲜数据。 如果为“final”(不区分大小写),或者如果省略此参数,则返回的数据将仅包含已最终确定的数据。 |
响应
系统会根据请求中指定的维度对结果进行分组。包含同一组维度值的所有值都会归为一行。例如,如果您按国家/地区维度进行分组,则“usa”的所有结果将归为一组,“mdv”的所有结果也将归为一组,以此类推。如果您按国家/地区和设备进行分组,则“美国、平板电脑”下的所有结果将被分组,“美国、移动设备”下的所有结果也将被分组,以此类推。请参阅“搜索分析”报告文档,详细了解点击次数、展示次数等指标的计算方式及其含义。
除非您按日期对结果进行分组,否则系统会按日期升序(由旧到新,由新到旧)对结果进行排序。如果两行相等,则排序顺序为任意顺序。
如需了解可以返回的值的数量上限,请参阅请求中的 rowLimit 属性。
{ "rows": [ { "keys": [ string ], "clicks": double, "impressions": double, "ctr": double, "position": double } ], "responseAggregationType": string }
属性名称 | 值 | 说明 | 备注 |
---|---|---|---|
rows[] |
list |
按查询中指定的顺序按键值分组的行列表。 | |
rows[].keys[] |
list |
相应行的维度值列表,按请求中的维度分组,并按请求中指定的顺序排列。 | |
rows[].clicks |
double |
点击相应行的计数。 | |
rows[].impressions |
double |
相应行的展示次数。 | |
rows[].ctr |
double |
相应行的点击率 (CTR)。值的范围为 0 到 1.0(含 0 和 1.0)。 | |
rows[].position |
double |
搜索结果中的平均排名。 | |
responseAggregationType |
string |
结果的汇总方式。请参阅帮助文档,了解按网站和按网页计算数据的方式有何不同。
可接受的值包括:
|
试试看!
使用下面的 API Explorer 对实际数据调用此方法,然后查看响应。