用新行从文本文件中分解连接字符串,PHP

Explode concatenate string from text file with new line, PHP

我正在尝试制作一个 table 包含从 A[1-20] 到 J[1-20] 的某种电影院座位。我有一个包含预留座位的 txt 文件,如下所示:

A2;
A1;
A3;
A7;

如果有座位,table的bgcolor必须是红色。这是完整的代码:

<?php 
$file = fopen($path,"r") or exit("cant open file");
$seat="";
while(!feof($file))
{
    $seat.= fgets($file);
}
$seat_splitted = explode(";",$seat);
fclose($file);

$arrTable[]="";
$letter="";
$tableContent="";

for($i = 0,$counter=0;$i<10;$i++,$counter++)
{
    if($i==0)
        $letter="A";
    else if($i==1)
        $letter="B";
    else if($i==2)
        $letter="C";
    else if($i==3)
        $letter="D";
    else if($i==4)
        $letter="E";
    else if($i==5)
        $letter="F";
    else if($i==6)
        $letter="G";
    else if($i==7)
        $letter="H";
    else if($i==8)
        $letter="I";
    else if($i==9)
        $letter="J";
?>
    <tr>
<?php
    for($j = 1;$j<21;$j++)
    {
        $arrTable[$counter]= $letter.$j;
        foreach($seat_splitted as $value)
        {
            if(strcmp($value,$arrTable[$counter])==0)
            //if($value == $letter.$j)
            {
                $GLOBALS['color']="red";
                break;
            }
            else
                $GLOBALS['color']="white";
        }
        ?>
        <td bgcolor="<?php echo $GLOBALS['color']; ?>"> <?php echo $arrTable[$counter]?> </td>
    <?php   
        $counter++;
    }
    ?>
    </tr>
<?php
}
?>

不知道为什么在if(strcmp($value,$arrTable[$counter])==0)或者//if($value == $letter.$j)的时候,只能抢到第一个座位"A2"。但是当我将 txt 文件更改为:

A2;A1;A3;A7;

IF 可以捕获它们。像这样连接字符串是错误的吗? $seat.= fgets($file);。我该怎么做才能让它与第一个 txt 文件一起工作?抱歉我的英语不好。

如果您像现在这样使用 explode,您将得到一个数组:

["A2","\nB1","\nC3"...]

所以你必须处理 \n

也许你可以试试explode(";\n",$seat)

更新:在某些系统中你需要使用\r\n。所以这是正确的最终解决方案:explode(";\r\n",$seat)

我认为这样的东西应该适合你。我把一切都简化了一点。

1。首先,我创建了一个包含所有座位的数组 ($seats)。其结构如下:

Array
(
    [A] => Array
        (
            [1] => free
            [2] => free
            [3] => free
            //...
    //...

2。在此之后,我将文件中的所有保留席位放入一个数组中。 (更好的解决方案是将所有这些数据都保存在数据库中!)

3。然后我遍历每个预留座位并将其设置为 $seats 数组中的那个,这样它就会得到如下内容:

Array
(
    [A] => Array
        (
            [1] => reserved
            [2] => free
            [3] => reserved
            //...
    //...

4。最后我简单地打印了 table

代码:

<?php

    //create seats
    $rows = range(strtoupper("A"), strtoupper("J"));
    $columns = range(1, 20);

    $seats = array_combine($rows, array_map(function($v)use($columns){
        return array_combine($columns, array_fill(0, count($columns), "free"));
    }, $rows));

    //get reserved seats
    $reservedSeats = array_map(function($v){
        return trim($v, ";");
    }, file("test.txt", FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES));

    //set reserved seats
    foreach($reservedSeats as $reserved) {
        $checkOne = preg_replace("/[^A-Z]*/", "", $reserved);
        $checkTwo = preg_replace("/[^0-9]*/", "", $reserved);

        if(isset($seats[$checkOne]) && isset($seats[$checkOne][$checkTwo]))
            $seats[$checkOne][$checkTwo] = "reserved";      
    }

    //print seats
    $reservedColor = "red";
    $defaultColor = "white";
    $rowColor = "green";

    echo "<table border='1'>";
    foreach($seats as $row) {
        echo "<tr><td bgcolor='" . $rowColor . "'>" . $rowKey . "</td>";
        foreach($row as $key => $seat)
            echo "<td bgcolor='" . ($seat == "reserved"?$reservedColor:$defaultColor) . "'>" . $key . "</td>";
        echo "</tr>";
    }
    echo "</table>";

?>

输出(无颜色):

A   1   2   3   4   5   6   7   8   9   10  11  12  13  14  15  16  17  18  19  20
B   1   2   3   4   5   6   7   8   9   10  11  12  13  14  15  16  17  18  19  20
C   1   2   3   4   5   6   7   8   9   10  11  12  13  14  15  16  17  18  19  20
D   1   2   3   4   5   6   7   8   9   10  11  12  13  14  15  16  17  18  19  20
E   1   2   3   4   5   6   7   8   9   10  11  12  13  14  15  16  17  18  19  20
F   1   2   3   4   5   6   7   8   9   10  11  12  13  14  15  16  17  18  19  20
G   1   2   3   4   5   6   7   8   9   10  11  12  13  14  15  16  17  18  19  20
H   1   2   3   4   5   6   7   8   9   10  11  12  13  14  15  16  17  18  19  20
I   1   2   3   4   5   6   7   8   9   10  11  12  13  14  15  16  17  18  19  20
J   1   2   3   4   5   6   7   8   9   10  11  12  13  14  15  16  17  18  19  20