С помощью PHP как вы выводите текстовый файл в таблицу вместе со ссылками - PullRequest
0 голосов
/ 07 декабря 2009

У меня есть этот текстовый файл:

Dec 04 20:15 Naruto 123
Dec 04 17:42 Naruto 98
Dec 04 16:19 D Gray Man 001
Dec 04 16:05 Bleach 128
Dec 04 12:13 50 x 50 44

Мне нужно вывести содержимое в таблицу с датой и временем в собственном столбце, а плиткой и главой - в другом.

Также ... Мне нужно заменить заголовок и главу ссылкой, которая должна быть отформатирована следующим образом:

<a href="/title/title chapter">title chapter</a>

Для пояснения заголовки в текстовом файле:

Naruto
Naruto
D Gray Man
Bleach
50 x 50

И главы следующие цифры:

123
98
001
128
44

Ответы [ 2 ]

1 голос
/ 07 декабря 2009

Примерно так и должно быть (не проверял код):

$data = Explode ( "\n", File_Get_Contents ( 'yourfile' ) );

foreach ( $data as $key => $line )
{
    $tmp = Explode ( ' ', $line );
    $month = $tmp[0];
    $day = $tmp[1];
    $time = $tmp[2];
    $numOfEntries = Count ( $tmp );
    $chapter = $tmp[$numOfEntries - 1];

    $title = '';
    for ( $i = 3; $i < $numOfEntries - 1; $i++ )
        $title .= $tmp[$i] . ' ';

    $title = Trim ( $title );

    $link = '<a href="/' . $title . '/' . $title . ' ' . $chapter . '">' . $title . ' ' . $chapter . '</a>';
}
0 голосов
/ 07 декабря 2009
  1. Чтение файла и сохранение каждой строки в массиве.
  2. Открыть <table> тег
  3. Перебрать массив и извлечь дату / время / заголовок / главу с помощью регулярных выражений.

Ниже приведено регулярное выражение - вы можете захотеть немного его изменить, чтобы удовлетворить ваши потребности:

/^([a-zA-Z]{3}\s\d{2})\s(\d{2}:\d{2})\s(.+?)\s(\d+)\s*?$/
//$1 contains date : "Dec 04"
//$2 contains time : "20:15"
//$3 contains the title : "Naruto"
//$4 contains the chapter : "123"

Для каждого элемента в массиве напишите соответствующие теги <tr> & <td>, заполненные извлеченными данными.

Обновление:

<?php
$filedata = "Dec 04 20:15 Naruto 123
Dec 04 17:42 Naruto 98
Dec 04 16:19 D Gray Man 001
Dec 04 16:05 Bleach 128
Dec 04 12:13 50 x 50 44";

$lines = explode("\n", $filedata);

echo "<table border=\"1\">";

foreach($lines as $line)
{
    echo "<tr>";
    preg_match("/^([a-zA-Z]{3}\s\d{2}\s\d{2}:\d{2})\s(.+?)\s(\d+)\s*?$/", $line, $matches);
    echo "<td>$matches[1]</td>";
    echo "<td><a href=\"/$matches[2]/$matches[2] $matches[3]\">$matches[2] $matches[3]</a></td>";
    echo "</tr>";
}
echo "</table>"
?>
...