大橙子网站建设,新征程启航

为企业提供网站建设、域名注册、服务器等服务

php随机读取一条数据 php获取随机数

通过php随机读取txt文件的某一行

PHP随机读取TXT文件的某一行,基本思路是这样的:获得总行数、产生随机数、获得随机行,例子代码如下:

目前成都创新互联已为成百上千的企业提供了网站建设、域名、网络空间、网站改版维护、企业网站设计、隆阳网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

?php

$f='1.txt';//文件名

$a=file($f);//把文件的所有内容获取到数组里面

$n=count($a);//获得总行数

$rnd=rand(0,$n);//产生随机行号

$rnd_line=$a[$rnd];//获得随机行

echo "$rnd / $n : $rnd_line \n"; //显示结果

?

以上程序在我的电脑上执行几次的结果如下:

E:\TEMP\文件\expa.php

1 / 8 : [00:05.33]你拿什么来爱我2

E:\TEMP\文件\expa.php

3 / 8 : acfp6o7ib----803sb7rmvz----1525175080=

E:\TEMP\文件\expa.php

1 / 8 : [00:05.33]你拿什么来爱我2

E:\TEMP\文件\expa.php

1 / 8 : [00:05.33]你拿什么来爱我2

E:\TEMP\文件\expa.php

5 / 8 : bxi2jw97----0vaf3bw17s----1525184793=

php中怎样从一个数组中随机取一个元素出来呢?

它的用法也很简单:array_rand($arr[, $num])$arr == 用来取元素的数组$num == 随机取下标的个数其中第二个参数 $num 是可选的,默认为1 。注意:它的返回值在第二个参数大于 1 的时候是一个数组;当第二个参数不设或者传值 1 的时候是一个下标。简单的示例代码如下:1、第二个参数不传值的情况;$arr = Array('a', 'b');$rndKey = array_rand($arr);echo $arr[$rndKey];//输出 a 或者 b2、第二个参数传值大于 1 的情况;$arr = Array('a', 'b', 'c', 'd');$rndKey = array_rand($arr, 2);print_r($rndKey]);//输出一个随机key的数组

php随机读取mysql中的一条消息,保证每次不重复

针对单独访客来存储该访客访问过的纪录, 只是能COOKIE了, 但这样的话清除浏览器COOKIE后就无效了. 大致思路是这样, 具体可能会有些逻辑需要优化.

?php

//访问

if (!isset($_COOKIE["visited"]) {

$_COOKIE["visited"] = "";

}

if ($_COOKIE["visited"] != "") {

$sql = "select * from table where id not in (" . $_COOKIE["visited"] . ") order by rand() limit 1";

} else {

$sql = "select * from table where order by rand() limit 1";

}

//访问取出纪录后, 得到该条纪录的ID $id, 将ID存入COOKIE

if ($_COOKIE["visited"] == "") {

$_COOKIE["visited"] = $id;

} else {

$_COOKIE["visited"] .= "," . $id;

}

如何在数据库中随机取出1条记录?PHP

/**

* MySQL 随机取记录

* @param $t 表

* @param $c ID列,默认为id

* @param $n 取多少个

* @param $w 条件语句

* @param $f bool 是否强制以多维数组形式返回,默认false

* @return array 取1个直接返回结果数组(除非$f为true),取1个返回多维数组,用foreach取出

*/

function rand_row($t , $c = 'id' , $n = '1', $w = '' , $f = false) {

$m=new mysqli(mysqli信息,自行查找php文档);

if (!empty($w)) {

$w = ' AND '.$w;

}

$sql = "SELECT * FROM `{$t}` WHERE {$c} = (SELECT floor(RAND() * (SELECT MAX({$c}) FROM `{$t}`))) {$w} ORDER BY {$c} LIMIT {$n};";

$xq  = $m-query($sql);

$r   = array();

while ($x = $m-fetch_array($xq)) {

$r[] = $x;

}

if ($f == false  count($r) == 1) {

return $r[0];

} else {

return $r;

}

}


当前文章:php随机读取一条数据 php获取随机数
网址分享:http://dzwzjz.com/article/dojejic.html
在线咨询
服务热线
服务热线:028-86922220
TOP