新しいopenCPUプラットフォームでは、HTML/javascript内にR関数を統合できます。しかし、私は実装に苦労してきました。誰かがあなたの自己設計されたR関数をopenCPUにアップロードし、javascriptを介してそのパラメーターでそれを呼び出す方法の例を提供できますか?
3142 次
3 に答える
3
上記のソリューションは、変更された openCPU サーバー パスと JSON サポートの欠如により、機能しなくなりました。変更された作業ソリューション
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Call R Through OpenCPU</title>
<script type="text/javascript" src="http://code.jquery.com/jquery-latest.js"></script>
<script>
//When Document is Ready
$(function () {
//Go R button Click Event Handler
$("#cmdGoR").click(function () {
var resultsUrlPrefix = "http://public.opencpu.org",
url = resultsUrlPrefix + "/ocpu/library/base/R/identity/save";
var rCommands = $("#txtRCommands").val();
$.post(url,
{
x: rCommands
},
function (data) {
var statResultsLink = resultsUrlPrefix + data.toString().match(/.+\/stdout/m),
chartLink = resultsUrlPrefix + data.toString().match(/.+\/graphics\/[1]/m);
//Add statistical (textual) results to results div
$('#results').append("<br/>");
$('<div/>', {
id: 'statResults'
}).appendTo('#results');
$("#statResults").load(statResultsLink);
//Add charts results to results div
$('#results').append("<br/>");
$('<img/>', {
id: 'chartResults',
src: chartLink
}).appendTo('#results');
})
.error(function (jqXHR, status, error) {
alert(jqXHR.responseText);
});
});
});
</script>
</head>
<body>
<h3>Set of R Commands</h3>
<textarea rows="8" cols="80" id="txtRCommands">
x <- rnorm(1000);
print(hist(x));
</textarea>
<br />
<input type="button" value="Run code" id="cmdGoR" />
<div id="results">
</div>
</body>
</html>
于 2015-10-31T08:48:03.097 に答える
2
これは、ジョブを実行するスタンドアロンの HTML ページです。それはリクエストをopenCPUサーバーに送信し、同じサーバー上の適切なオブジェクトを指すキーを持つjsonオブジェクトを取得し、ページに挿入します。コードをダウンロードして、[コードを実行] ボタンをクリックするだけです。
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Call R Through OpenCPU</title>
<script type="text/javascript" src="http://code.jquery.com/jquery-latest.js"> </script>
<script>
//When Document is Ready
$(function () {
//Go R button Click Event Handler
$("#cmdGoR").click(function () {
var resultsUrlPrefix = "http://public.opencpu.org/R/tmp/";
var url = "http://public.opencpu.org/R/call/base/identity/save";
var rCommands = $("#txtRCommands").val();
$.post(url,
{
x: rCommands
},
function (data) {
var obj = $.parseJSON(data);
//Add statistical (textual) results to results div
$('#results').append("<br/>");
$('<div/>', {
id: 'statResults'
}).appendTo('#results');
var statResultsLink = resultsUrlPrefix + obj.object + "/print";
$("#statResults").load(statResultsLink);
//Add charts results to results div
var charts = obj.graphs;
if (charts.length > 0) {
for (var i = 0; i < charts.length; i++) {
var chartLink = resultsUrlPrefix + charts[i] + "/png";
$('#results').append("<br/>");
$('<img/>', {
id: 'chartResults' + (i + 1),
src: chartLink
}).appendTo('#results');
}
}
})
.error(function (jqXHR, status, error) {
alert(jqXHR.responseText);
});
});
});
</script>
</head>
<body>
<h3>Set of R Commands</h3>
<textarea rows="8" cols="80" id="txtRCommands">
x <- rnorm(1000);
print(hist(x));
</textarea>
<br />
<input type="button" value="Run code" id="cmdGoR" />
<div id="results">
</div>
</body>
</html>
于 2013-04-05T19:49:46.040 に答える
0
ヒントをありがとう。私はあなたのアプリから簡単な例のコードを推測しようとしました (blow を参照)。重要でないものはすべて切り取り、ボタンを押した後に単純な R コードを実行するだけのコマンドを作成しました。しかし、私が理解できなかった間違いがあるようです。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>openCPU example 1</title>
<script src="http://code.jquery.com/jquery-latest.js"></script>
</head>
<body>
<div class="container">
<form action="http://public.opencpu.org/R/pub/base/identity/ascii" method="POST" id="knitForm">
<button id="run">Run script</button>
<div id="result"></div>
</form>
</div>
<script>
$('#run').click(function() {
$('#knitForm').submit();
});
/* attach a submit handler to the form */
$('#knitForm').submit(function(event) {
/* stop form from submitting normally */
event.preventDefault();
/* get some values from elements on the page: */
var $form = $( this ),
term = ‘{my_func <- function(a,b){plot(a,b);}; my_func(2,3);}‘,
url = $form.attr('action')
/* Send the data using post and put the results in a div */
$.post(url, { term },
function( data ) {
$("#result").html(eval(data));
$('pre code').each(function(i, e) {hljs.highlightBlock(e)});
})
.complete(function() {$('#run').attr('class', 'btn');})
.error(function() { alert("An error occurred!"); });
});
</script>
</body>
</html>
于 2012-07-12T12:53:18.760 に答える