php编程 之 php进阶练习

摘要:
1.PHP日期相关操作:PHP date()函数可以将时间戳格式化为可读性更强的日期和时间<?phpechodate(“Y/m/d”)。“<br>”;//返回2016/10/21回声(“Y.m.d”)。“<br>”//返回2016.10.21 echo(“Y-m-d”)//返回2016-10-21>注:小时、分钟和秒的格式如下:$t

1,php的date相关操作:

PHP date() 函数可把时间戳格式化为可读性更好的日期和时间。

<?php
echo date("Y/m/d") . "<br>";  //返回2016/10/21
echo date("Y.m.d") . "<br>";    //返回2016.10.21
echo date("Y-m-d");    //返回2016-10-21
?>

注意:带着时分秒的格式是这样的:$t=date("Y.m.d.H.i.s")

  调用这个函数以前,最好是先设定一下时区:date_default_timezone_set('Asia/Shanghai');(前面这句话直接加在开头就行)

完整的format字符可查询下表:
format字符说明返回值例子
------
d月份中的第几天,有前导零的 2 位数字01 到 31
D星期中的第几天,文本表示,3 个字母Mon 到 Sun
j月份中的第几天,没有前导零1 到 31
l("L"的小写字母)星期几,完整的文本格式Sunday 到 Saturday
NISO-8601 格式数字表示的星期中的第几天(PHP 5.1.0 新加)1(表示星期一)到 7(表示星期天)
S每月天数后面的英文后缀,2 个字符stndrd 或者 th。可以和 j 一起用
w星期中的第几天,数字表示0(表示星期天)到 6(表示星期六)
z年份中的第几天0 到 365
星期------
WISO-8601 格式年份中的第几周,每周从星期一开始(PHP 4.1.0 新加的)例如:42(当年的第 42 周)
------
F月份,完整的文本格式,例如 January 或者 MarchJanuary 到 December
m数字表示的月份,有前导零01 到 12
M三个字母缩写表示的月份Jan 到 Dec
n数字表示的月份,没有前导零1 到 12
t给定月份所应有的天数28 到 31
------
L是否为闰年如果是闰年为 1,否则为 0
oISO-8601 格式年份数字。这和 Y 的值相同,只除了如果 ISO 的星期数(W)属于前一年或下一年,则用那一年。(PHP 5.1.0 新加)Examples: 1999 or 2003
Y4 位数字完整表示的年份例如:1999 或 2003
y2 位数字表示的年份例如:99 或 03
时间------
a小写的上午和下午值am 或 pm
A大写的上午和下午值AM 或 PM
BSwatch Internet 标准时000 到 999
g小时,12 小时格式,没有前导零1 到 12
G小时,24 小时格式,没有前导零0 到 23
h小时,12 小时格式,有前导零01 到 12
H小时,24 小时格式,有前导零00 到 23
i有前导零的分钟数00 到 59>
s秒数,有前导零00 到 59>
u毫秒 (PHP 5.2.2 新加)。需要注意的是 date() 函数总是返回 000000 因为它只接受 integer 参数, 而 DateTime::format() 才支持毫秒。示例: 654321
时区------
e时区标识(PHP 5.1.0 新加)例如:UTCGMTAtlantic/Azores
I是否为夏令时如果是夏令时为 1,否则为 0
O与格林威治时间相差的小时数例如:+0200
P与格林威治时间(GMT)的差别,小时和分钟之间有冒号分隔(PHP 5.1.3 新加)例如:+02:00
T本机所在的时区例如:ESTMDT(【译者注】在 Windows 下为完整文本格式,例如"Eastern Standard Time",中文版会显示"中国标准时间")。
Z时差偏移量的秒数。UTC 西边的时区偏移量总是负的,UTC 东边的时区偏移量总是正的。-43200 到 43200
完整的日期/时间------
cISO 8601 格式的日期(PHP 5 新加)2004-02-12T15:19:21+00:00
rRFC 822 格式的日期例如:Thu, 21 Dec 2000 16:01:07 +0200
U从 Unix 纪元(January 1 1970 00:00:00 GMT)开始至今的秒数参见 time()

2,文件相关操作:

打开文件:

<?php
$file=fopen("filename.txt","r");
?>

  文件打开模式详情见下表:

模式描述
r只读。在文件的开头开始。
r+读/写。在文件的开头开始。
w只写。打开并清空文件的内容;如果文件不存在,则创建新文件。
w+读/写。打开并清空文件的内容;如果文件不存在,则创建新文件。
a追加。打开并向文件末尾进行写操作,如果文件不存在,则创建新文件。
a+读/追加。通过向文件末尾写内容,来保持文件内容。
x只写。创建新文件。如果文件已存在,则返回 FALSE 和一个错误。
x+读/写。创建新文件。如果文件已存在,则返回 FALSE 和一个错误。

关闭文件:fclose($filename);

检测是否到达文件末尾:

if (feof($filename)) echo "文件结尾";

逐行读取文件:

<?php
$file = fopen("welcome.txt", "r") or exit("无法打开文件!");
// 读取文件每一行,直到文件结尾
while(!feof($file))    //如果没有到达文件末尾
{
    echo fgets($file). "<br>";    //就逐行读取文件
}
fclose($file);    //到了末尾就关闭
?>

逐字读取文件:

<?php
$file=fopen("welcome.txt","r") or exit("无法打开文件!");
while (!feof($file))
{
    echo fgetc($file);    //注意,fgetc()函数,这是逐字读取。
}
fclose($file);
?>

拓展:php读取文件的五种方法:

第一种:

<?php
$file_path = "test.txt";
if(file_exists($file_path)){
$fp = fopen($file_path,"r");
$str = fread($fp,filesize($file_path));//指定读取大小,这里把整个文件内容读取出来
echo $str = str_replace("
","<br />",$str);
}
?>

第二种

<?php
$file_path = "test.txt";
if(file_exists($file_path)){
$str = file_get_contents($file_path);//将整个文件内容读入到一个字符串中
$str = str_replace("
","<br />",$str);
echo $str;
}
?>

第三种

<?php
$file_path = "test.txt";
if(file_exists($file_path)){
$fp = fopen($file_path,"r");
$str = "";
$buffer = 1024;//每次读取 1024 字节
while(!feof($fp)){//循环读取,直至读取完整个文件
$str .= fread($fp,$buffer);
} 
$str = str_replace("
","<br />",$str);
echo $str;
}
?>

第四种:

<?php
$file_path = "test.txt";
if(file_exists($file_path)){
$file_arr = file($file_path);
for($i=0;$i<count($file_arr);$i++){//逐行读取文件内容
echo $file_arr[$i]."<br />";
}
/*
foreach($file_arr as $value){
echo $value."<br />";
}*/
}
?>

第五种:比较推荐用这个。

<?php
$file_path = "test.txt";
if(file_exists($file_path)){
$fp = fopen($file_path,"r");
$str ="";
while(!feof($fp)){
$str .= fgets($fp);//逐行读取。如果fgets不写length参数,默认是读取1k。
}
$str = str_replace("
","<br />",$str);
echo $str;
}
?>

3,跨文件调用函数

t1.php文件:作用在于把当前时间写到txt文档中,然后一行一行读取,读到的信息加工一下,展示出来。

<?php
function wgTime()
{
    date_default_timezone_set('Asia/Shanghai'); 
    $t=date("Y.m.d.H.i.s")."
";
    //var_dump($t);
    $file=fopen("t1.txt","a");
    fwrite($file,$t);
    fclose($file);
    $file="t1.txt";
    if(file_exists($file)){
        $file_arr=file($file);    //行读取
        for ($i=0;$i<count($file_arr);$i++){
            $str=explode(".",$file_arr[$i]);
            $dw=array("Y ","M ","D ","H ","I ","S ");
            for ($j=0;$j<6;$j++){
        //echo $j."序号"."<br>";
                echo $str[$j],$dw[$j];
            }
            echo "<br>";
        }
    }
}
//wgTime();    因为调用的时候会直接执行,所以要注释掉才好调用
?>

在daqing.php文件中如果想要调用t1.php的方法,可以这样:

<?php
require_once "t1.php";    //表示调用一次
wgTime();
?>

 4,php数据库相关操作:

  补充:die() 函数输出一条消息,并退出当前脚本。该函数是 exit() 函数的别名。

           $rowcount=mysqli_num_rows($result),mysqli_num_rows()函数返回记录数。

      mysqli_fetch_assoc()是一个读取数据库数据的函数,它会一行一行地读取,并且把读到的数据转化成数组,数组的键是数据库的列名,值是具体的数。比如,读取id 和currtime,id=1,currtime=2018.09.05.12.12.12,这个函数就会生成这样的数组:'currtime' => '2018.09.05.10.58.06  'id'=>1。

  连接数据库:

//mysqli-面向对象
<?php
$servername="localhost";
$username="xxx";
$password="xxx";
$conn=new mysqli($servername,$username,$password);
if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
} 
echo "连接成功";
?>
//mysqli-面向过程 <?php $servername = "localhost"; $username = "username"; $password = "password"; $conn = mysqli_connect($servername, $username, $password); if (!$conn) { die("Connection failed: " . mysqli_connect_error()); } echo "连接成功"; ?>

个人比较倾向于面向过程的这种方法,因为特殊符号比较少。

  创建数据表:

<?php
$servername = "localhost";
$username = "xxx";
$password = "xxx";
$dbname="daqingdb";    //在这里可以直接加入datebase参数。
$conn = mysqli_connect($servername, $username, $password,$dbname);
if (!$conn) {
    die("Connection failed: " . mysqli_connect_error());
}
echo "连接成功 <br>";
$sql="create table wgtime (`id` int(4) unsigned auto_increment primary key,time varchar(20) not null)";
if (mysqli_query($conn,$sql)){
    echo "创建table:wgTime 成功!<br>";
}else{
    echo "创建表error".mysqli.error($conn);
}
mysqli_close($conn);
echo "exitd!";
?>

 把时间写入数据库,并且读取出来:

<?php
date_default_timezone_set('Asia/Shanghai');
$t=date("Y.m.d.H.i.s")."
";
$servername = "localhost";
$username = "xxx";
$password = "xxx";
$dbname="daqingdb";    //在这里可以直接加入datebase参数。
$conn = mysqli_connect($servername, $username, $password,$dbname);
if (!$conn) {
    die("Connection failed: " . mysqli_connect_error());
}
echo "连接成功 <br>";
// $sql="create table wgtime (`id` int(4) unsigned auto_increment primary key,currtime varchar(30) not null)";
// if (mysqli_query($conn,$sql)){
//     echo "创建table:wgTime 成功!<br>";
// }else{
//     echo "创建表error".mysqli.error($conn);
// }
$sql1="INSERT INTO `wgtime`(`currtime`) VALUES ('$t')";    //$t要用单引号表明
if (mysqli_query($conn,$sql1)){
    echo "新纪录插入成功 <br>";
}else{
    echo "error:".mysqli_error($conn);    //打印出mysql返回的错误
}
//$sql2="select * from `wgtime`";
$sql2="select `currtime` from `wgtime`";
$result=mysqli_query($conn,$sql2);
//var_dump($result);    $result竟然是个object对象类!其方法或者属性有:current_field,field_count,lengths,num_rows,type.
if (mysqli_num_rows($result)>0){    //mysqli_num_rows($result)返回数据库中查询到的记录的行数
    echo "查询成功<br>";
    while ($row=mysqli_fetch_assoc($result)){
        //var_dump($row); 这是一个数组,类似于字典吧。
        $dw=array("Y ","M ","D ","H ","I ","S ");
        $str=explode(".",$row["currtime"]);        
        for($i=1;$i<6;$i++){
            echo $str[$i],$dw[$i]; 
        }
        echo "<br>";
    }
}else{
    echo "error:".mysqli_error($conn);
}
mysqli_close($conn);
echo "exitd!";
?>

 5,php文件和目录相关操作。

补充:

  file_exists()判断文件或者文件夹是否存在,返回布尔值

  $list=scandir($dirpath)读取$dirpath代表的位置的下面的文件。

  chdir(path)改变当前文件位置到指定地方,约等于文件夹的指针。 

<?php
function dirBuilder($d,$t,$note)    //参数分别是:文件夹名,文件名,文件内容
{
    // date_default_timezone_set('Asia/Shanghai');    //也可以不用参数,改用时间
    // $d=date("Y年m月d日");
    // $t=date("H时i分s秒");
    // $note="hello";
    $dirpath="C:/xampp/htdocs/daqing_new/dir_test/$d";    //判断文件夹是否存在,不存在就创建
    if (!file_exists($dirpath)){
        mkdir($dirpath,0777,true);
        //echo "新建文件夹<br>";
    }

    chdir($dirpath);    
    //echo "改变当前文件夹<br>";
    if (file_exists("C:/xampp/htdocs/daqing_new/dir_test/$d/$t.txt")){    //判断是否有同名文件
        echo "文件已经存在,没有创建新的<br>";
    }else{
        //echo "文件不存在,新建<br>";
        $myfile=fopen("$t.txt",'w');
        fwrite($myfile,$note);
        fclose($myfile);
    }
    $list=scandir($dirpath);    //读取文件夹下的文件目录
    var_dump($list);    //$list是一个数组,带着文件名和length,不能直接打印
    for($i=2;$i<count($list);$i++){
        echo "$list[$i] <br>";
    }
}
dirBuilder('123',"345","hello i am daqing");
?>

 6,php和html混写

第一种方法:单双引号包围法

<?php
echo '
<!DOCTYPE html>
<html>
    <head>
        <title> </title>
    </head>
    <body>
        <span>测试页面</span>
    </body>
</html>
';
?>
//返回:测试页面

单双引号的方法是一样的,但是单双引号有区别,单引号不会解析内部的变量,双引号支持变量的解析。

缺点在于:

  输出的内容中包含引号的话不好处理;编辑器不好提醒引号内部的格式错误。

第二种,使用EOF标识,这种方法支持变量解析

<?php
$content='hello';echo <<<EOF
‘$content’
EOF
?>
//返回:'hello',证明这种方法支持单双引号的使用

第三种,html中嵌入php程序块

  基本思想:提前定义好函数或者方法,然后在需要输出的地方写上代码就可以了。

<?php
function test(){
    echo "function test! <br>";
}
?>    //方法或者函数需要写在<?php  ?>中,下文的输出也要写在这样的格式中

<!DOCTYPE html>    //html语句不需要写在<?php ?>中,php会理解的。
<html>
    <head>
        <title><?php test();?> </title>
    </head>
    <body>
        <span><?php test();echo 'lala';?></span>
    </body>
</html>

//输出:function test! <br> lala

第四种,使用前端模板引擎

  比如,我们可以使用Smarty,当然了,目前并不能理解。

相关技术的关系:

  HTML展示内容
  PHP动态修改输出HTML展示内容
  CSS美化页面
  JS让页面动起来。提高浏览体验。

制作一个键:

<html>

<head>
<meta charset="utf-8">    //在标题里,定义了网页的元信息,比如编码方式charset
<title>    //title标签,会显示在浏览器窗口的头上
大晴测试
</title>
</head>

<body>
<button name= "logup" type = "submit" >呵呵</button>    //button中定义的是这个按键的属性
</body>

</html>

免责声明:文章转载自《php编程 之 php进阶练习》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇eclipse 使用总结google搜索技巧下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

mybatis 在自动生成时设置不生成Example类

只需要在配置要生成的table表中添加几个配置属性就行了。在generatorConfig.xml文件中修改 <!--指定数据库表--> <table tableName="t_user" schema="" > <generatedKey column="userId" sql...

greenplum(postgresql) 数据字典

greenplum是基于postgresql开发的分布式数据库,里面大部分的数据字典是一样的。我们在维护gp的时候对gp的数据字典比较熟悉,特此分享给大家。在这里不会详细介绍每个字典的内容,只会介绍常见的应用以及一些已经封装好了的函数。具体的介绍大家可以去看postgresql的中文文档(附件),里面有详细的解释。 1.postgresql中,所有数据库的...

Linux部署Tomcat、JDK、MySQL(详细步骤)

一、Tomcat安装 1.将tomcat安装包apache-tomcat-7.0.57-windows-x64.zip在本地解压后放到/usr/local目录 2.修改解压后的目录的权限 [root@localhost local]# chmod -cfvR 777 apache-tomcat-7.0.57/ 3.修改环境变量: [root@localho...

sql-优化建议

1. 查询 SQL 尽量不要使用 select *,而是 select 具体字段 反例: select * from employee; 正例: select id,name from employee; 理由: 只取需要的字段,节省资源、减少网络开销; select * 进行查询时,很可能就不会使用到覆盖索引了,就会造成回表查询。 2. 如果知道...

pthread实现多线程查询(转)

导读:大多数网站的性能瓶颈不在PHP服务器上,因为它可以简单地通过横向增加服务器或CPU核数来轻松应对(对于各种云主机,增加VPS或CPU核数就更方便了,直接以备份镜像增加VPS,连操作系统、环境都不用安装配置),而是在于MySQL数据库。如果用 NoSQL 数据库,也许需要十次查询,才能处理完同样地业务逻辑。此时PHP多线程的作用非常明显,它可以同时执行...

使用docker搭建gitlab服务器

简单记录Docker的使用和GitLab的搭建 ## Docker基础篇 ### 没有sudo权限 ### 安装docker ### 基础命令 ### docker安装mysql和配置 ### Dockerfile常用命令 ### 制作镜像 ### 发布镜像 ### 容器网络 ### Docker Compose ### Swarm模式 集群## 正式搭建...