用换行符PHP分解文本文件中的连接字符串


Explode concatenate string from text file with new line, PHP

我试图让一张桌子由a[1-20]到J[1-20]的某种电影院座位组成。我有一个txt文件,其中包含保留的座位,如下所示:

A2;
A1;
A3;
A7;

如果预订了座位,桌子的背景色必须是红色。这是完整的代码:

<?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;

国际单项体育联合会可以抓住所有人。像这样连接字符串是错误的吗?$seat.= fgets($file);。我该怎么做才能使它与第一个txt文件一起工作?抱歉我英语不好。

我认为这样的东西应该对你有用。我把每件事都简化了一点。

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

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

2.在这之后,我将文件中的所有预留座位都放入一个数组中。(一个更好的解决方案是,如果你在数据库中有所有这些数据!)

3.然后我循环浏览每个保留的座位,并将其设置为$seats数组中的座位,这样它就会得到这样的结果:

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

4.最后,我简单地打印了表格

代码:

<?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

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

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

所以你必须处理'n

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

更新:在某些系统中,您需要使用''r''n。因此,这里是正确的最终解决方案:explode(";'r'n",$seat)