0

有人可以指点我正确的方向,将我的开关代码从当前列出的如下所示转换为从 CSV 文件中提取:

    $video = (isset($_GET['video']) ? $_GET['video'] : null);

if($video) {
    switch($video) {
        case "apple":
                    $Heading ='Apple Heading';
            $Videonum ='1';
            $Content ='<h2>Apple Sub Heading</h2>
                               <p>Apple content</p>';
            $SideContent ='Apple side content';
break;

我最终会处理很多案例,并且从 .csv 文件管理起来会更容易 - 谢谢

4

2 回答 2

0

我认为您需要一个二维数组,其中标识符 ('apple', ...) 作为内部数组的键。通过解析 CSV 文件,您将获得一个包含多行的数组,但您需要搜索包含所需数据的行。也许您还可以保存包含必要数据数组的 PHP 文件,甚至使用数据库(这可能是这种情况下最常见的)。

我会使用它的目标数组:

$data = array(
    'apple' => array(
        'heading' => 'Apple Heading',
        'video_num' => 1,
        'content' => '<h2>Apple Sub Heading</h2>
                      <p>Apple content</p>',
        'side_content' => 'Apple side content',
    ),
    /* more manufacturer sub-arrays */
);

在第一种情况下,您只需从数组中读取即可访问整个数据:

if( !empty( $_GET['video'] ) && isset( $data[$_GET['video']] ) )
{
    var_dump(
        $data[$_GET['video']]['heading'],
        $data[$_GET['video']]['content']
    );
}
else
{
    echo '<p class="error">No video specified or "' . $_GET['video'] . '" is not available.</p>';
}

供参考; 从 CSV 文件中检索的数组:

$data = array(
    1 => array(
        'manufacturer' => 'Apple',
        'heading' => 'Apple Heading',
        'video_num' => 1,
        'content' => '<h2>Apple Sub Heading</h2>
                      <p>Apple content</p>',
        'side_content' => 'Apple side content',
    ),
    /* more rows */
);
于 2012-07-26T09:49:08.847 回答
0

阅读您的 csv 文件

$data = array();
$fp = fopen('manufacturer.csv', 'r');
while (!feof($fp)) {
    $line = explode(';',fgets($fp));
    $data[$line[0]]['heading'] = $line[1];
    $data[$line[0]]['video'] = $line[2];
    $data[$line[0]]['content'] = $line[3];
    $data[$line[0]]['side'] = $line[4];
}
fclose($fp);

你的 csv 看起来像

apple;Apple Heading;1;<h2>Apple Sub Heading</h2><p>Apple content</p>;Apple side content
microsoft;MS Heading;1;<h2>MS Sub Heading</h2><p>MS content</p>;MS side content
...

然后使用制造商名称访问您的内容

if(isset($data[$_GET['video']] && !empty($_GET['video']))){
    $Heading = $data[$_GET['video']]['heading'];
    $Videonum = $data[$_GET['video']]['video'];
    $Content = $data[$_GET['video']]['content'];
    $SideContent = $data[$_GET['video']]['side'];
}
于 2012-07-26T09:52:59.210 回答