[英]Using GET via URL to load 1 entry from CSV file in PHP
我正在使用一个简单的php新闻脚本,我希望该选项可以查看单个帖子(而不是仅查看文件中当前的工作方式的每个帖子)。
这是在前端使用的代码,我不确定我需要做什么,但是我知道它涉及到GET参数...
<?php
//get news class and array
include_once('newsadmin/includes/newsTools.class.inc.php');
$newsTools = new newsTools('newsadmin/csv/news.csv');
$news_headlines = $newsTools->getNewsArray();
//output news array as formatted html
if (!count($news_headlines)>0){
echo '<p>There are currently no news headlines.</p>';
}else{
foreach ($news_headlines as $key => $item){
list($news_id,$news_date,$news_title,$news_body) = $item;
$formatted_date = date('F j, Y, g:i a',$news_date);
echo <<<HTML
<a name="$news_id" id="$news_id"></a>
<h1 style="margin-bottom: 20px;">$news_title</h1>
$news_body
<p><span>Posted: $formatted_date</span></p>
<hr />
HTML;
}
}
?>
我认为这与以下行有关:foreach($ news_headlines as $ key => $ item){
提前致谢 :)
我的建议是更改getNewsArray()
方法,以不同方式构建$news_headlines
数组。
因此,没有像这样的数组:
[
['NEWS ID VALUE', 'NEWS DATE VALUE', 'NEWS TITLE VALUE', 'NEWS BODY VALUE'],
['NEWS ID VALUE 2', 'NEWS DATE VALUE 2', 'NEWS TITLE VALUE 2', 'NEWS BODY VALUE 2'],
...
]
您可以构建一个像这样的数组:
[
'NEWS ID VALUE' => ['NEWS DATE VALUE', 'NEWS TITLE VALUE', 'NEWS BODY VALUE'],
'NEWS ID VALUE 2' => ['NEWS DATE VALUE 2', 'NEWS TITLE VALUE 2', 'NEWS BODY VALUE 2'],
...
]
这里的新闻ID是关联数组中的键。 这样做是允许您从数组中查找新闻项,而不必遍历数组。 所以可以这样做:
//get news class and array
include_once('newsadmin/includes/newsTools.class.inc.php');
$newsTools = new newsTools('newsadmin/csv/news.csv');
$news_headlines = $newsTools->getNewsArray();
if(!empty($_GET['news_id'])) {
// a single news item was requested
$news_id = $_GET['news_id'];
if (isset($news_headlines[$news_id])) {
// the news item was found in the array
$news_item = $news_headlines[$news_id];
// display your story
var_dump($news_id,$news_item);
} else {
// they requested an invalid news item, show some error here
}
} else {
//output news array as formatted html
if (!count($news_headlines)>0){
echo '<p>There are currently no news headlines.</p>';
} else {
foreach ($news_headlines as $news_id => $item){
list($news_date,$news_title,$news_body) = $item;
$formatted_date = date('F j, Y, g:i a',$news_date);
?>
<a name="<?php echo $news_id; ?>" id="<?php echo $news_id; ?>"></a>
<h1 style="margin-bottom: 20px;"><?php echo $news_title; ?></h1>
<?php echo $news_body; ?>
<p><span>Posted: <?php echo $formatted_date; ?></span></p>
<hr />
<?php
}
}
}
?>
如果CSV文件中包含大量项目,则可能还需要考虑将这些数据移至数据库中。 这样可以避免只需要一个项目时就将所有数据加载到内存中的需求,并且还可以使您更轻松地执行诸如按日期排序,按日期范围显示记录等操作(如果您想执行此类操作)下线。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.