php - 将开关转换为.csv文件读取方法

时间:2012-07-26 09:36:18

标签: php csv switch-statement

有人可以指出我正确的方向将我的开关代码从当前列出如下所示转换为从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文件管理起来会更容易 - 谢谢

2 个答案:

答案 0 :(得分: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>';
}

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

答案 1 :(得分: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'];
}