gpt4 book ai didi

xml - Google 表格的 IMPORTXML XPath_Query

转载 作者:数据小太阳 更新时间:2023-10-29 02:28:39 26 4
gpt4 key购买 nike

我正在使用 GoogleSheet 的 IMPORTXML 函数来检索一年前的每个日历日期或最近的可用数据的一年前日期的数据。

这是数据样本 ( full data source is here ):

 <entry>
<id>http://data.treasury.gov/Feed.svc/DailyTreasuryYieldCurveRateData(6794)</id>
<title type="text"></title>
<updated>2018-02-06T22:05:38Z</updated>
<author>
<name />
</author>
<link rel="edit" title="DailyTreasuryYieldCurveRateDatum" href="DailyTreasuryYieldCurveRateData(6794)" />
<category term="TreasuryDataWarehouseModel.DailyTreasuryYieldCurveRateDatum" scheme="http://schemas.microsoft.com/ado/2007/08/dataservices/scheme" />
<content type="application/xml">
<m:properties>
<d:Id m:type="Edm.Int32">6794</d:Id>
<d:NEW_DATE m:type="Edm.DateTime">2017-02-24T00:00:00</d:NEW_DATE>
<d:BC_1MONTH m:type="Edm.Double">0.4</d:BC_1MONTH>
<d:BC_3MONTH m:type="Edm.Double">0.52</d:BC_3MONTH>
<d:BC_6MONTH m:type="Edm.Double">0.65</d:BC_6MONTH>
<d:BC_1YEAR m:type="Edm.Double">0.8</d:BC_1YEAR>
<d:BC_2YEAR m:type="Edm.Double">1.12</d:BC_2YEAR>
<d:BC_3YEAR m:type="Edm.Double">1.38</d:BC_3YEAR>
<d:BC_5YEAR m:type="Edm.Double">1.8</d:BC_5YEAR>
<d:BC_7YEAR m:type="Edm.Double">2.12</d:BC_7YEAR>
<d:BC_10YEAR m:type="Edm.Double">2.31</d:BC_10YEAR>
<d:BC_20YEAR m:type="Edm.Double">2.69</d:BC_20YEAR>
<d:BC_30YEAR m:type="Edm.Double">2.95</d:BC_30YEAR>
<d:BC_30YEARDISPLAY m:type="Edm.Double">2.95</d:BC_30YEARDISPLAY>
</m:properties>
</content>
</entry>
<entry>
<id>http://data.treasury.gov/Feed.svc/DailyTreasuryYieldCurveRateData(6795)</id>
<title type="text"></title>
<updated>2018-02-06T22:05:38Z</updated>
<author>
<name />
</author>
<link rel="edit" title="DailyTreasuryYieldCurveRateDatum" href="DailyTreasuryYieldCurveRateData(6795)" />
<category term="TreasuryDataWarehouseModel.DailyTreasuryYieldCurveRateDatum" scheme="http://schemas.microsoft.com/ado/2007/08/dataservices/scheme" />
<content type="application/xml">
<m:properties>
<d:Id m:type="Edm.Int32">6795</d:Id>
<d:NEW_DATE m:type="Edm.DateTime">2017-02-27T00:00:00</d:NEW_DATE>
<d:BC_1MONTH m:type="Edm.Double">0.44</d:BC_1MONTH>
<d:BC_3MONTH m:type="Edm.Double">0.5</d:BC_3MONTH>
<d:BC_6MONTH m:type="Edm.Double">0.68</d:BC_6MONTH>
<d:BC_1YEAR m:type="Edm.Double">0.81</d:BC_1YEAR>
<d:BC_2YEAR m:type="Edm.Double">1.2</d:BC_2YEAR>
<d:BC_3YEAR m:type="Edm.Double">1.46</d:BC_3YEAR>
<d:BC_5YEAR m:type="Edm.Double">1.87</d:BC_5YEAR>
<d:BC_7YEAR m:type="Edm.Double">2.18</d:BC_7YEAR>
<d:BC_10YEAR m:type="Edm.Double">2.36</d:BC_10YEAR>
<d:BC_20YEAR m:type="Edm.Double">2.72</d:BC_20YEAR>
<d:BC_30YEAR m:type="Edm.Double">2.98</d:BC_30YEAR>
<d:BC_30YEARDISPLAY m:type="Edm.Double">2.98</d:BC_30YEARDISPLAY>
</m:properties>
</content>
</entry>
<entry>

这是我目前用于检索 2017 年 2 月 27 日数据的 XPath 查询:

//*[local-name() = 'NEW_DATE'][text() = '2017-02-27T00:00:00']/..

这是显示的结果:

6795    2017-02-27T00:00:00 0.44    0.5 0.68    0.81    1.2 1.46    1.87    2.18    2.36    2.72    2.98    2.98

有没有办法:

  1. 检索显示的所有数据,除了“d:Id”元素(上面的“6795”)和
  2. 如果搜索没有数据的日期(例如 2017Feb 25 将导致“#N/A”错误,因为查询不会为缺失的日期返回任何内容),查询将默认为下一个可用的远期日期(例如 2017 年 2 月 27 日)?

我避免使用 IF 函数以减少 IMPORTXML 调用。

最佳答案

这个答案怎么样?

第一个问题

示例:

=TRANSPOSE(IMPORTXML(A1, "//*[local-name() = 'NEW_DATE'][text() = '2017-02-27T00:00:00']/../*[local-name()!='Id']"))
  • “A1”是http://data.treasury.gov/feed.svc/DailyTreasuryYieldCurveRateData?$filter=year(NEW_DATE)%20eq%202017的网址.
  • 对于 //*[local-name() = 'NEW_DATE'][text() = '2017-02-27T00:00:00']/.. , 除 <d:Id m:type="Edm.Int32">6795</d:Id> 之外的值被检索到。
  • 结果被转置,因为值被输出到行。

结果:

enter image description here

第二个问题

=TRANSPOSE(IMPORTXML(A1, "//*[local-name() = 'NEW_DATE'][text() = '2017-02-25T00:00:00']/../*[local-name()!='Id']"))使用 #N/A 的结果被检索。

如果我误解了你的问题,我很抱歉。

关于xml - Google 表格的 IMPORTXML XPath_Query,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48795106/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com