0

所以我有两个文本文件,一个名为 users.txt 和 schedule.txt。schedule.txt 如下所示:(注意上面的数字不在文件中,它们用作用户文件的参考)

   0           1     2

2013-04-11^12:00|4:00|14:00

    3          4     5     6

2013-07-21^10:00|15:00|18:00|15:00

    7          8

2013-12-11^13:00|14:00

users.txt 文件如下所示:

约翰·史密斯^2|4|6

星球大战^0|1|3|6

卢克·天行者^2|6|7|8

并且这些数字中的每一个都对应于另一个文件的索引...例如,John Smith 在 2013 年 4 月 11 日有一个时间 14:00(从 2 开始),时间是 15:00(从 4 开始)等等……

好吧,我使用 HTML 为所有这些构建了一个表格,但我无法提取时间值(例如 12:00)。

此外,我对 html 和 PHP 非常陌生,所以请放轻松...请如果您有指针或任何其他有用的信息,请分享 =)当我尝试添加编辑时,我肯定会需要它(用于编辑时间这使用单选按钮)并添加新用户。

非常感谢您的任何帮助/建议!

这是我的代码:

<?php
<!DOCTYPE html>
<html>
 <head>
  <title>Scheduler</title>
 </head>
 <body>
<h2>
<center>Select Your Meeting Times</center></h2>
    <table border="1"
    cellpadding="10">
    <tr>
    <th>User</th>
    <th>Action</th>
    <?php 
    //error_reporting(0);
    date_default_timezone_set('America/New_York');
    // used for displaying schedule times 
        $schedule= file('schedule.txt');
        // loop through array and output contents

        foreach($schedule as $s) {
            list($year, $month, $day) = explode('-', $s); 
            $ga = explode("|", $s);
            var_dump($year); 
            //echo $ga[5];


                            $year= intval($year, 10);
            $month= intval($month, 10);
            $day= intval($day, 10); 

            $h = mktime(0, 0, 0, $month, $day,$year);
            $d = date("F dS, Y", $h); //used to get the day of the week 
            $w= date("l", $h); // w now holds the day of the week.

            foreach($schedule as $t)
            {   
                // $split = preg_split('/| /', $t, -1, PREG_SPLIT_NO_EMPTY);



                list($time) = explode("|", $t); 
                list($time1) = explode(" ", $time); 
            //  var_dump($time1); 
            //  $output = trim($time1); 
            //  echo $test; 
                echo "<th>" . $w . "<br>" . $month . "/" . $day . "/" . $year . "</th>\n";


            }




        }


    ?>
    </tr>
    <tr>
     <?php
            $text = file('user.txt');
            // loop through array and output contents
            foreach($text as $user) {
                list($u) = explode('^', $user);
                echo "<tr>" . "<td>" . $u . "</td>" . "</tr>\n";
            }
        ?>
    </tr>
    <tr>
    <th><br></th>
    </tr>
    <tr>
    <th>Total</th>
    </tr>

    </table>


 </body>
</html>
4

3 回答 3

0

我为你写了一个小班。我没有包括任何错误检查。第一次之后仍然有点困惑,^所以我在代码中添加了关于如何包含它的注释。另请注意,我没有评论代码,希望您能理解。

class UserTime{
    var $data=array();
    function __construct(){
        $lines = file('test.txt', FILE_IGNORE_NEW_LINES);
        foreach ($lines as $l){
            list($d,$t)=explode('^', $l);
            $this->data[]=$d;
            $t=explode('|', $t);
            // you have to remove the following line if you want to
            // include the first time after ^
            array_shift($t);
            $this->data = array_merge($this->data,$t);
        }
    }
    function getUser($user_string){
        list($user_name,$ix)=explode('^', $user_string);
        $userData['userName']=$user_name;
        $userData['time']=array();
        $idx = explode('|', $ix);
        for($i=0;$i<count($idx);$i++){
            if(isset($this->data[$idx[$i]])){
                $userData['time'][]=$this->data[$idx[$i]];
            }
        }
        return $userData;
    }
}

你可以使用下面的类

$users = new UserTime();
$udata = $users->getUser('John Smith^2|4|6');
print_r($udata);
$udata = $users->getUser('Star Wars^0|1|3|6');
print_r($udata);

输出如下。我认为您可以自己在 HTML 中使用它。

Array
(
    [userName] => John Smith
    [time] => Array
        (
            [0] => 14:00
            [1] => 15:00
            [2] => 15:00
        )

)
于 2013-09-13T04:13:06.783 回答
0

请不要这样做。如果您想使用文本文件(对于可以的小型应用程序),请使用合理的文本格式。去掉所有这些自定义分隔符,只使用 CSV 格式(您可以使用fgetcsv()将一行读入数组),或者更好的是,使用带有适当标签的JSON格式(使用json_decode()解压它)和你的麻烦在提取时间会蒸发。

您也不需要所有的恶意提取日期 - 查找DateTime::createFromFormat()并让自己的生活变得轻松。

于 2013-09-13T03:17:07.103 回答
0

上面的人已经评论了存储信息的更好方法,但要回答您关于 extract() 的问题:

当你这样做时

list($year, $month, $day) = explode('-', "2013-04-11^12:00|4:00|14:00"); 

你得到"11^12:00|4:00|14:00"的价值$day,而不是"11"。同样,当你这样做时

$ga = explode("|", "2013-04-11^12:00|4:00|14:00");

你得到"2013-04-11^12:00"第一个值。从您的其余代码来看,这可能不是您想要的。

于 2013-09-13T03:21:22.173 回答