1

PythonベースのWebサーバーを構築しています(はい、Python は Web サーバーには適していませんが、これしか選択肢がありません。私の目的には、PHP などの別の優れた選択肢がありますが、私は python に制限されています)。

データの視覚化に ProtoVis を使用しています。(JavaScript ベースの可視化ツール)

次のコードは、コピーしてテスト ファイルに貼り付け、.html の名前を変更するだけで機能します (その横に protovis ライブラリが抽出されている場合)。

試してみたい場合は、こちらから入手してください https://github.com/mbostock/protovis/zipball/v3.3.1

<html>
    <head>
        <title>Area Chart</title>
        <link type="text/css" rel="stylesheet" href="ex.css?3.2"/>
        <script type="text/javascript" src="protovis/protovis.js"></script>
        <style type="text/css">
        #fig {
            width: 430px;
            height: 225px;
        }
        </style>
    </head>
    <body>
    <div id="center">
    <div id="fig">
    <script type="text/javascript+protovis">
    
var data = pv.range(0, 10, .1).map(function(x) {
    return {x: x, y: Math.sin(x) + Math.random() * .5 + 2};
  });
    
/* Sizing and scales. */
var w = 400,
    h = 200,
    x = pv.Scale.linear(data, function(d) d.x).range(0, w),
    y = pv.Scale.linear(0, 4).range(0, h);

/* The root panel. */
var vis = new pv.Panel()
    .width(w)
    .height(h)
    .bottom(20)
    .left(20)
    .right(10)
    .top(5);

/* Y-axis and ticks. */
vis.add(pv.Rule)
    .data(y.ticks(5))
    .bottom(y)
    .strokeStyle(function(d) d ? "#eee" : "#000")
  .anchor("left").add(pv.Label)
    .text(y.tickFormat);

/* X-axis and ticks. */
vis.add(pv.Rule)
    .data(x.ticks())
    .visible(function(d) d)
    .left(x)
    .bottom(-5)
    .height(5)
  .anchor("bottom").add(pv.Label)
    .text(x.tickFormat);

/* The area with top line. */
vis.add(pv.Area)
    .data(data)
    .bottom(1)
    .left(function(d) x(d.x))
    .height(function(d) y(d.y))
    .fillStyle("rgb(121,173,210)")
  .anchor("top").add(pv.Line)
    .lineWidth(3);

vis.render();

    </script>
    </div>
    </div>
    </body>
</html>

ただし、baseHTTPserver で上記のコードを返すと、うまくいかないようです。調べたところ、「protovis/protovis.js」にあるライブラリが正しくインクルードされていないようです。

if url[0] == "/chart":
    self.send_response(200)
    self.send_header("Content-type","text/html")
    self.end_headers()
    self.wfile.write(chart())
    return

chart() 関数は上記の行を返します。

CentOS 6.2 で Python 2.6 を使用していますが、使用している JavaScript ライブラリを含めるために baseHTTPserver で何か特別なことをする必要がありますか? 同じコードが Apache + PHP で正常に機能し、単純にエコーしました。

何か案が?

======================== ソリューション =======================

Apache+PHP とは異なり、BaseHTTPServer は、そのフォルダーに入れたものを提供するだけではありません。マシューが説明したように、自分で行うか、別のサーバーから protovis.js を提供する必要があります (別のポートで実行されている SimpleHTTPServer の場合もあります)。– ヴァシリー・ファロノフ

以下の Matthew Adams の指示を参照してください。

この問題を解決するために私がしなければならなかったことは、JavaScript ファイルを処理する別のメソッドを do_GET() に追加することでした。

if url[0] == "/protovis/protovis.js":
    f = open("protovis/protovis.js","rb")
    for each_line in f:
        self.wfile.write(each_line)
    return

問題を解決します。

解決策をありがとう、本当に感謝しています

4

1 に答える 1

2

protovis/protovis.jsBaseHTTPServer を使用してサービスを提供していることを確認してください。<script type="text/javascript" src="protovis/protovis.js"></script>基本的に、ブラウザーは、取得した html 出力を読み取るときにその行を「見て」、サーバーが実際に protovis/protovis.js ファイルを送信するように要求しますその github ダウンロードに python コードが表示されていないため、コードのコンテキストでこれを行う方法を具体的に示すことはできませんが、チェックアウトしてくださいSimpleHTTPRequestHandler。これを使用して、サーバーが要求されたとき (つまりisのとき) にdo_GET()送信するようにメソッドに追加できます。protovis/protovis.jsself.pathprotovis/protovis.js

于 2012-06-27T16:47:58.443 に答える