how to insert csv file in the dygraph link interaction

Deadly 提交于 2019-12-25 02:58:24

问题


i got this example for link interaction in dygraph but i don't know how to link my csv file with this. i tried replacing r with my csv file., pls guide me., i tried like this by declaring r as te1.csv i get blank graph

<!DOCTYPE html>
<html>
  <head>
    <title>noise</title>
     <script type="text/javascript"
  src="https://cdnjs.cloudflare.com/ajax/libs/dygraph/1.1.0/dygraph-combined-dev.js"></script>
  <script type="text/javascript"
  src=" http://dygraphs.com/dygraph-dev.js"></script>

  </head>
  <body>
    <div id="div_g"></div>
    <div id="output"></div>
    <b>Zoom:</b>
      <a href="#" onclick="zoom(3600)">hour</a>
      <a href="#" onclick="zoom(86400)">day</a>
      <a href="#" onclick="zoom(604800)">week</a>
      <a href="#" onclick="zoom(30 * 86400)">month</a>
      <a href="#" onclick="reset()">full</a>
    <b>Pan:</b>
      <a href="#" onclick="pan(-1)">left</a>
      <a href="#" onclick="pan(+1)">right</a>

    <script type="text/javascript">
    var r = ["te1.csv" ];
      var base_time = Date.parse("date");
      var num = 24 * 0.25 * 365;
      for (var i = 0; i < num; i++) {
        r.push([ new Date(base_time + i * 3600 * 1000),
                 
               ]);
      }
      var orig_range = [ r[0][0].valueOf(), r[r.length - 1][0].valueOf() ];
    
     var date = new Date(),
            output = document.getElementById( 'output' ),
            dateString = date.getMonth() + 1 + "/" + date.getDate() + "/" + date.getFullYear().toString().substr(2,2);
               
        output.innerHTML = dateString;
        
       
      g2 = new Dygraph(
            document.getElementById("div_g"),
            r, {
              rollPeriod: 7,
              animatedZooms: true,
              // errorBars: true,
              width: 1000,
              height: 500,
             xlabel: 'date',
                                ylabel: 'Pressure',
            }
          );
      var desired_range = null;
      function approach_range() {
        if (!desired_range) return;
        // go halfway there
        var range = g2.xAxisRange();
        if (Math.abs(desired_range[0] - range[0]) < 60 &&
            Math.abs(desired_range[1] - range[1]) < 60) {
          g2.updateOptions({dateWindow: desired_range});
          // (do not set another timeout.)
        } else {
          var new_range;
          new_range = [0.5 * (desired_range[0] + range[0]),
                       0.5 * (desired_range[1] + range[1])];
          g2.updateOptions({dateWindow: new_range});
          animate();
        }
      }
      function animate() {
        setTimeout(approach_range, 50);
      }
      function zoom(res) {
        var w = g2.xAxisRange();
        desired_range = [ w[0], w[0] + res * 1000 ];
        animate();
      }
      function reset() {
        desired_range = orig_range;
        animate();
      }
      function pan(dir) {
        var w = g2.xAxisRange();
        var scale = w[1] - w[0];
        var amount = scale * 0.25 * dir;
        desired_range = [ w[0] + amount, w[1] + amount ];
        animate();
      }
    </script>
  </body>
</html>

in this i completely removed r and declared csv file directly o/p is its reading csv but day,month,year is showing jan 1 2011 data which is not there in csv file

<!DOCTYPE html>
<html>
  <head>
    <title>noise</title>
     <script type="text/javascript"
  src="https://cdnjs.cloudflare.com/ajax/libs/dygraph/1.1.0/dygraph-combined-dev.js"></script>
  <script type="text/javascript"
  src=" http://dygraphs.com/dygraph-dev.js"></script>

  </head>
  <body>
    <div id="div_g"></div>
    <div id="output"></div>
    <b>Zoom:</b>
      <a href="#" onclick="zoom(3600)">hour</a>
      <a href="#" onclick="zoom(86400)">day</a>
      <a href="#" onclick="zoom(604800)">week</a>
      <a href="#" onclick="zoom(30 * 86400)">month</a>
      <a href="#" onclick="reset()">full</a>
    <b>Pan:</b>
      <a href="#" onclick="pan(-1)">left</a>
      <a href="#" onclick="pan(+1)">right</a>

    <script type="text/javascript">


      g2 = new Dygraph(
            document.getElementById("div_g"),
          te1.csv, {
              rollPeriod: 7,
              animatedZooms: true,
              // errorBars: true,
              width: 1000,
              height: 500,
             xlabel: 'date',
                                ylabel: 'Pressure',
            }
          );
      var desired_range = null;
      function approach_range() {
        if (!desired_range) return;
        // go halfway there
        var range = g2.xAxisRange();
        if (Math.abs(desired_range[0] - range[0]) < 60 &&
            Math.abs(desired_range[1] - range[1]) < 60) {
          g2.updateOptions({dateWindow: desired_range});
          // (do not set another timeout.)
        } else {
          var new_range;
          new_range = [0.5 * (desired_range[0] + range[0]),
                       0.5 * (desired_range[1] + range[1])];
          g2.updateOptions({dateWindow: new_range});
          animate();
        }
      }
      function animate() {
        setTimeout(approach_range, 50);
      }
      function zoom(res) {
        var w = g2.xAxisRange();
        desired_range = [ w[0], w[0] + res * 1000 ];
        animate();
      }
      function reset() {
        desired_range = orig_range;
        animate();
      }
      function pan(dir) {
        var w = g2.xAxisRange();
        var scale = w[1] - w[0];
        var amount = scale * 0.25 * dir;
        desired_range = [ w[0] + amount, w[1] + amount ];
        animate();
      }
    </script>
  </body>
</html>

i got the above code from this example

<!DOCTYPE html>
    <html>
      <head>
        <title>graph</title>
        <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/dygraph/1.1.0/dygraph-combined-dev.js"></script>
   
    <script type="text/javascript" src=" http://dygraphs.com/dygraph-dev.js"></script>

      </head>
      <body>
        <div id="div_g"></div>
        <b>Zoom:</b>
          <a href="#" onclick="zoom(3600)">hour</a>
          <a href="#" onclick="zoom(86400)">day</a>
          <a href="#" onclick="zoom(604800)">week</a>
          <a href="#" onclick="zoom(30 * 86400)">month</a>
          <a href="#" onclick="reset()">full</a>
        <b>Pan:</b>
          <a href="#" onclick="pan(-1)">left</a>
          <a href="#" onclick="pan(+1)">right</a>

        <script type="text/javascript">
// removed from here to
          var r = [ ];
          var base_time = Date.parse("2008/07/01");
          var num = 24 * 0.25 * 365;
          for (var i = 0; i < num; i++) {
            r.push([ new Date(base_time + i * 3600 * 1000),
                     i + 50 * (i % 60),        // line
                     i * (num - i) * 4.0 / num  // parabola
                   ]);
          }
          var orig_range = [ r[0][0].valueOf(), r[r.length - 1][0].valueOf() ]; // up to here removed
          g = new Dygraph(
                document.getElementById("div_g"),
                r,// i replaced csv file here 
{
                  rollPeriod: 7,
                  animatedZooms: true,
                  // errorBars: true,
                  width: 600,
                  height: 300,
                  labels: ["Date", "a", "b"]
                }
              );
          var desired_range = null;
          function approach_range() {
            if (!desired_range) return;
            // go halfway there
            var range = g.xAxisRange();
            if (Math.abs(desired_range[0] - range[0]) < 60 &&
                Math.abs(desired_range[1] - range[1]) < 60) {
              g.updateOptions({dateWindow: desired_range});
              // (do not set another timeout.)
            } else {
              var new_range;
              new_range = [0.5 * (desired_range[0] + range[0]),
                           0.5 * (desired_range[1] + range[1])];
              g.updateOptions({dateWindow: new_range});
              animate();
            }
          }
          function animate() {
            setTimeout(approach_range, 50);
          }
          function zoom(res) {
            var w = g.xAxisRange();
            desired_range = [ w[0], w[0] + res * 1000 ];
            animate();
          }
          function reset() {
            desired_range = orig_range;
            animate();
          }
          function pan(dir) {
            var w = g.xAxisRange();
            var scale = w[1] - w[0];
            var amount = scale * 0.25 * dir;
            desired_range = [ w[0] + amount, w[1] + amount ];
            animate();
          }
        </script>
      </body>
    </html>

i replaced r with csv file but the filter of month,hour,day,week is not working

来源:https://stackoverflow.com/questions/31397499/how-to-insert-csv-file-in-the-dygraph-link-interaction

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!