2

抱歉,如果这可能是一个简单的问题,我之前没有使用过平面文件数据库并且发现这非常不直观。

我有一个平面文件、制表符\t\n新行分隔的数据库,如下所示:

Sebastian Ingrosso  Kidsos (Wippenberg Mix) 2F32829628  Electro
Avicii  Silhouettes 2F47987574 House

(两行仅用于示例)。我希望能够遍历每一行,封装由\t标签内的制表符分隔的每个元素span,然后移动到下一行,最好将每个新行封装在一个<li>元素中。

我有这个开始,它不添加跨度或李:

function display_tracklist($max) {
$db = fopen('db/db.txt', 'r');
$row = 0;
while (($tracks = fgetcsv($db, "\n")) !== FALSE) {
    if ($max > count($tracks)) {
        $max = count($tracks);
    }
    $row++;
    for ($index=0; $index < $max; $index++) {
        echo "<li>" . $tracks[$index] . "</li>";
    }
}
fclose($db);

}

处理此任务的最佳方法是什么?通常,我会使用 SQL 数据库来完成此操作,从而使事情变得更加直观,但这不是这里的选择。我想到了嵌套的 foreach 循环等,到目前为止还没有运气。

最终结果应该是: <li><span>Sebastian Ingrosso</span> <span>Kidsos (Wippenberg Mix)</span> <span>2F32829628</span> <span>Electro</span></li> <li><span>Avicii</span> <span>Silhouettes</span> <span>2F32829628</span> <span>House</span></li>

等等

4

1 回答 1

1

假设你的数据和我的一样$data,这看起来就像给了你想要的;

$data = "Sebastian\tIngrosso\tKidsos (Wippenberg Mix)\t2F32829628\tElectro\nAvicii\tSilhouettes\t2F47987574\tHouse";
foreach ((array) explode("\n", $data) as $lines) {
    print "<li>";
    foreach ((array) explode("\t", $lines) as $line) {
        print "<span>{$line}</span>";
    }
    print "</li>\n";
}

输出;

<li><span>Sebastian</span><span>Ingrosso</span><span>Kidsos (Wippenberg Mix)</span><span>2F32829628</span><span>Electro</span></li>
<li><span>Avicii</span><span>Silhouettes</span><span>2F47987574</span><span>House</span></li>
于 2013-02-15T22:36:09.443 回答