将switchch转换为.csv文件读取方法


converting swithch to .csv file read method

有人能告诉我正确的方向吗?将我的开关代码从下面列出的代码转换为从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文件管理会更容易-谢谢

我认为您需要一个以标识符('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>';
}

FYI;从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 */
);

读取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'];
}