簡體   English   中英

使用通過URL的GET從PHP的CSV文件加載1個條目

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM