価格履歴などの株式情報を使用する株式分析 Web サイトを構築しています。データを取得したら独自のアルゴリズムをいくつか実装しますが、履歴データの取得に問題があります。Web サイトは無料の Web ホスティングでホストされています。 biz.nfの 含まれている connect.php ファイルには、必要なすべての SQL 情報が含まれており、データベースに接続します。そこにエラーチェックがあるので、それが問題ではないことはわかっています。また、リンクを手動でコピーして貼り付けようとしましたが、機能するため、URL を適切に作成しています。このウェブサイトや他のウェブサイトで同様のトピックに出くわしましたが、それを修正する明確な解決策や、それが起こっている明確な理由がわかりません. ヤフーは私をブロックしていますか?また、私はphpプログラミングにはまったく慣れていませんが、CとC ++の深いバックグラウンドを持っているので、できれば助けを提供するときにこれを考慮してください. 前もって感謝します!
実行される index.php ファイルのコードは次のとおりです。
コード:
<html>
<head>
<title>StockGrader</title>
</head>
<body bgcolor="green" text="black" link="red">
<div id="header">
<hr>
<h1>Welcome To <b><i>StockGrader</b></i><h1/></hr>
<?php
include("phpINCLUDES/connect.php");
//function that creates a url from which to download data
function createURL($ticker)
{ $currentMonth = date("n") - 1; //"n" current month as a 1-digit number
$currentDay = date("j"); //"j" current day as a 1-digit number
$currentYear = date("Y"); //"Y" current year as a 4-digit number
echo "current URL is http://ichart.finance.yahoo.com/table.csv?s=$ticker&d=$currentMonth&e=$currentDay&f=$currentYear&g=d&a=3&b=10&c=2013&ignore=.csv";
echo "\n\n\n";
return "http://ichart.finance.yahoo.com/table.csv?s=$ticker&d=$currentMonth&e=$currentDay&f=$currentYear&g=d&a=3&b=10&c=2013&ignore=.csv";
}
//function to download data from a url and store into a file
function getCSVFile($URL, $outputFile)
{
**$content = file_get_contents($URL);** //goes to the file located at this link and downloads the full file contents as a string of data
//replace a string which is the first parameter with the string in the second parameter. the string being replaced is in the third parameter
$content = str_replace("Date,Open,High,Low,Close,Volume,Adj Close","", $content);
//removes all white space
$content = trim($content);
//write a string into a file
file_put_contents($outputFile, $content);
}
function fileToDatabase($txtFile, $tableName)
{
$file = fopen($txtFile, "r");
while(!feof($file))
{
$line = fgets($file);
//separates a string
$pieces = explode(",", $line);
//stock variables
$date = $pieces[0];
$open = $pieces[1];
$high = $pieces[2];
$low = $pieces[3];
$close = $pieces[4];
$volume = $pieces[5];
// $adjclose = $pieces[6]; WE ARE NOT GOING TO USE THIS ONE USUALLY
$amount_change = $close - $open;
if($open!=0)
{ $percent_change = ($amount_change/$open)*100; }
else $percent_change = 99999;
//check if table exists or not
$sql = "SELECT * FROM $tableName";
$result = mysql_query($sql);
//if table doesn't exist
if(!$result)
{
$sql_2 = "CREATE TABLE $tableName (date DATE , PRIMARY KEY(date), open FLOAT, high FLOAT, low FLOAT, close FLOAT, volume INT, amount_change FLOAT, percent_change FLOAT)";
mysql_query($sql_2);
}
//insert into table
$sql_3 = "INSERT INTO $tableName(date, open, high, low, close, volume, amount_change, percent_change) VALUES ('$date','$open','$high','$low','$close','$volume','$amount_change','$percent_change')";
mysql_query(sql_3);
}
fclose($file);
}
function main()
{
//i don't have this file yet
$mainTickerFile = fopen("tickerMaster.txt","r");
while(!feof($mainTickerFile))
{
$companyTicker = fgets($mainTickerFile);
$companyTicker = trim($companyTicker); //trim whitespace just in case
$fileURL = createURL($companyTicker); //create url for each stock ticker
//create a directory path to each file for each ticker
$companyTxtFile = "txtFiles/".$companyTicker.".txt"; //I NEED TO CREATE THIS FOLDER ON MY SERVER
getCSVFile($fileURL, $companyTxtFile);
fileToDatabase($companyTxtFile, $companyTicker);
}
}
main();
?>
<p><a href="secondpage.html">Run Script</a></p>
</div>
</body>
</html>
これは私が得ているエラーです:
[function.file-get-contents]: failed to open stream: Connection refused in /srv/disk12/1368341/www/nemanja.co.nf/index.php on line 26
エラーが発生しているテキストを太字 (両側に 2 つのアスタリスク) にしました。
また、ウェブサイトをホストしているサーバーには allow_url_fopen = 1 があります。yahoo.com が私をブロックしている場合、これを回避する方法はありますか? 過去の株式データをすべて取得する別の方法はありますか?