首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >google sheets在url处未找到重要的url资源-雅虎财经

google sheets在url处未找到重要的url资源-雅虎财经
EN

Stack Overflow用户
提问于 2021-11-09 12:24:59
回答 1查看 43关注 0票数 1

我尝试使用importxml从雅虎财经获取Walgreen的全职员工数量,如下所示:

代码语言:javascript
复制
=importxml("https://finance.yahoo.com/quote/WBA/profile", "/html/body/div[1]/div/div/div[1]/div/div[3]/div[1]/div/div[1]/div/div/section/div[1]/div/div/p[2]/span[6]/span")

我已经成功地使用该函数从雅虎财经获得了其他数据。示例(市值):

代码语言:javascript
复制
=mid(importxml("https://finance.yahoo.com/quote/WBA", "/html/body/div[1]/div/div/div[1]/div/div[3]/div[1]/div/div[1]/div/div/div/div[2]/div[2]/table/tbody/tr[1]/td[2]/span"),1,6)+0

但随着员工的数量(顺便说一句,还有过去12个月(ttm)的收入)-我得到了这个错误。

如果没有我不熟悉的VBA,如何解决这个问题?

谢谢!

EN

回答 1

Stack Overflow用户

发布于 2021-11-09 12:53:16

这个站点是由javascript构建的客户端,而不是服务器端。因此,本机函数是不起作用的。

您必须提取源代码中的json并对其进行解析。

该对象在源代码中被命名为root.App.main

例如,要获取员工

代码语言:javascript
复制
function fullTimeEmployees(url='https://finance.yahoo.com/quote/WBA/profile'){
  var source = UrlFetchApp.fetch(url).getContentText()
  var jsonString = source.match(/root.App.main = ([\s\S\w]+?);\n/)
  if (!jsonString || jsonString.length == 1) return;
  var data = JSON.parse(jsonString[1].trim())
  Logger.log(data.context.dispatcher.stores.QuoteSummaryStore.assetProfile.fullTimeEmployees)
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69898102

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档