【问题标题】:Parsing Nation stock exchange data and creating chart解析国家证券交易所数据并创建图表
【发布时间】:2014-02-12 10:36:28
【问题描述】:

我正在尝试获取国家证券交易所数据并使用 Google 图表创建图表。但我不知道如何解析我使用 api 获得的数据。这是api的代码。任何帮助将不胜感激。输出看起来像这样http://theawesomecoder.com/calc/chart.php

<?php
$curlSession = curl_init();
curl_setopt($curlSession, CURLOPT_URL, 'http://www.nseindia.com/live_market/dynaContent/live_watch/option_chain/optionKeys.jsp?symbolCode=-10007&symbol=NIFTY&symbol=NIFTY&instrument=OPTIDX&date=-&segmentLink=17&segmentLink=17');
curl_setopt($curlSession,CURLOPT_USERAGENT,'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.13) Gecko/20080311 Firefox/2.0.0.13');
curl_setopt($curlSession, CURLOPT_BINARYTRANSFER, true);
curl_setopt($curlSession, CURLOPT_RETURNTRANSFER, true);
$homepage = curl_exec($curlSession);



var_dump($homepage);

curl_close($curlSession);
?>

【问题讨论】:

  • 输出是什么样子的?
  • 您对哪一列数据感兴趣?
  • 我已经把输出看起来如何的链接theawesomecoder.com/calc/chart.php
  • 没关系。但是您要解析出哪一列并绘制图表?那里有无数列。
  • 我要解析行权价格列

标签: php jquery parsing stock


【解决方案1】:

如果你想正确地完成这项工作,你应该在服务器端完成这一切,请参考这个答案:

How do you parse and process HTML/XML in PHP?

否则这应该可以更快地解决您的问题:

<html>
<head>
   <meta content="text/html; charset=UTF-8" http-equiv="content-type">
   <script src="//code.jquery.com/jquery-1.11.0.js" type="text/javascript"></script>
   <script type="text/javascript">
      $(window).load(function(){
         var strikePrice = new Array();
         $(".opttbldata").find("tr").each( function (row, currentTR) {
            if (row > 1) { // Avoid first two header rows (0 based index)
                var columnContent = $(currentTR).find("td:eq( 6 )").text();
                strikePrice[row-2] = (columnContent=="-"?" 0":columnContent); // Strike price column (0 based index)
            }
         });
         $("#NSEIndiaData").remove(); // Get rid of the loaded page/data to uncluter the DOM
         alert(strikePrice);
      });
   </script>
</head>

<body>
   <?php
      $curlSession = curl_init();
      curl_setopt($curlSession, CURLOPT_URL, 'http://www.nseindia.com/live_market/dynaContent/live_watch/option_chain/optionKeys.jsp?symbolCode=-10007&symbol=NIFTY&symbol=NIFTY&instrument=OPTIDX&date=-&segmentLink=17&segmentLink=17');
      curl_setopt($curlSession,CURLOPT_USERAGENT,'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.13) Gecko/20080311 Firefox/2.0.0.13');
      curl_setopt($curlSession, CURLOPT_BINARYTRANSFER, true);
      curl_setopt($curlSession, CURLOPT_RETURNTRANSFER, true);
      $homepage = curl_exec($curlSession);
   ?>

   <div id="NSEIndiaData" style="display: none;">
      <?php var_dump($homepage); ?>
   </div>

   <?php
      curl_close($curlSession);
   ?>
</body>
</html>

第 12 列的所有值都将放在一个基于 0 索引的数组中,您以后可以随意操作该数组。

【讨论】:

  • 假设我想解析在 Strike Price 之前的 Ask Qty 列,我需要在代码中进行哪些更改。问候
  • 我试图做出这样的改变,但它不起作用。strikePrice[row-2] = $(currentTR).find("td:eq(10)").text();
  • 究竟是什么不起作用? Here 它工作正常。但是当然有些单元格有一个破折号“-”,我想这意味着它是一个零。
  • 是的,所以我想得到 0 而不是正在显示的警报中的那些破折号
  • 我完全同意你的帮助很大
猜你喜欢
  • 1970-01-01
  • 2020-02-27
  • 1970-01-01
  • 2019-01-21
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多