博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHP常用函数总结(180多个)
阅读量:5888 次
发布时间:2019-06-19

本文共 23313 字,大约阅读时间需要 77 分钟。

  1. PHP常用函数总结
  2. 数学函数
  3. 1.abs(): 求绝对值
  4. $abs = abs(-4.2); //4.2 数字绝对值数字
  5. 2.ceil(): 进一法取整
  6. echo ceil(9.999); // 10 浮点数进一取整
  7. 3.floor(): 舍去法取整
  8.     echo floor(9.999); // 9 浮点数直接舍去小数部分
  9. 4.fmod(): 浮点数取余
  10. ?
  11. 1
  12. 2
  13. 3
  14. 4
  15.  
  16. $x = 5.7;
  17. $y = 1.3; // 两个浮点数,x>y 浮点余数
  18. $r = fmod($x, $y);
  19. // $r equals 0.5, because 4 * 1.3 + 0.5 = 5.7
  20.  
  21. 5.pow(): 返回数的n次方
  22.     echo pow(-1, 20); // 1 基础数|n次方乘方值
  23. 6.round(): 浮点数四舍五入
  24.     echo round(1.95583, 2); // 1.96, 一个数值|保留小数点后多少位,默认为0 舍入后的结果
  25. 7.sqrt(): 求平方根
  26.     echo sqrt(9); //3 被开方的数平方根
  27. 8.max(): 求最大值
  28.     echo max(1, 3, 5, 6, 7); // 7
  29. 多个数字或数组 返回其中的最大值
  30.     echo max(array(2, 4, 5)); // 5
  31. 9.min(): 求最小值
  32. 输入: 多个数字或数组
  33. 输出: 返回其中的最小值
  34. 10.mt_rand(): 更好的随机数
  35. 输入: 最小|最大, 输出: 随机数随机返回范围内的值
  36.     echo mt_rand(0,9);//n
  37. 11.rand(): 随机数 输入: 最小|最大, 输出: 随机数随机返回范围内的值
  38. 12.pi(): 获取圆周率值
  39. 去空格或或其他字符:
  40. 13.trim(): 删除字符串两端的空格或其他预定义字符
  41. ?
  42. 1
  43. 2
  44.  
  45. $str = "\r\nHello World!\r\n";
  46. echo trim($str);
  47.  
  48. 输入: 目标字符串 返回值: 清除后的字符串
  49. 14.rtrim(): 删除字符串右边的空格或其他预定义字符
  50. ?
  51. 1
  52. 2
  53.  
  54. $str = "Hello World!\n\n";
  55. echo rtrim($str);
  56.  
  57. 15.chop(): rtrim()的别名
  58. 16.ltrim(): 删除字符串左边的空格或其他预定义字符
  59.  
  60. ?
  61. 1
  62. 2
  63.  
  64. $str = "\r\nHello World!";
  65. echo ltrim($str);
  66.  
  67. 17.dirname(): 返回路径中的目录部分
  68.     echo dirname("c:/testweb/home.php");  //c:/testweb
  69. 输入: 一个包含路径的字符串 返回值: 返回文件路径的目录部分
  70. 字符串生成与转化:  
  71. 18.str_pad(): 把字符串填充为指定的长度
  72. ?
  73. 1
  74. 2
  75.  
  76. $str = "Hello World";
  77. echo str_pad($str,20,".");
  78.  
  79. 输入: 要填充的字符串|新字符串的长度|供填充使用的字符串, 默认是空白
  80. 输出: 完成后的字符串
  81. 19.str_repeat(): 重复使用指定字符串
  82.     echo str_repeat(".",13); // 要重复的字符串|字符串将被重复的次数13个点
  83. 20.str_split(): 把字符串分割到数组中
  84. print_r(str_split("Hello"));
  85. 输入: 要分割的字符串|每个数组元素的长度,默认1
  86. 输出: 拆分后的字符串数组
  87. 21.strrev(): 反转字符串
  88.     echo strrev("Hello World!"); // !dlroW olleH
  89. 输出: 目标字符串颠倒顺序后的字符串
  90. 22.wordwrap(): 按照指定长度对字符串进行折行处理
  91. ?
  92. 1
  93. 2
  94. 3
  95.  
  96. $str = "An example on a long word is:
  97. Supercalifragulistic";
  98. echo wordwrap($str,15);
  99.  
  100. 输入: 目标字符串|最大宽数
  101. 输出: 折行后的新字符串
  102. 23.str_shuffle(): 随机地打乱字符串中所有字符
  103.     echo str_shuffle("Hello World");
  104. 输入: 目标字符串顺序 输出: 打乱后的字符串
  105. 24.parse_str(): 将字符串解析成变量
  106. ?
  107. 1
  108. 2
  109.  
  110. parse_str("id=23&name=John%20Adams", $myArray);
  111. print_r($myArray);
  112.  
  113. 输入: 要解析的字符串|存储变量的数组名称
  114. 输出: 返回Array( [id] => 23 [name] => John Adams)
  115. 25.number_format(): 通过千位分组来格式化数字 输入: 要格式化的数字|规定多少个小数|规定用作小数点的字符 串|规定用作千位分隔符的字符串
  116. 输出: 1,000,000 1,000,000.00 1.000.000,00
  117. 大小写转换:
  118. 26.strtolower(): 字符串转为小写
  119.     echo strtolower("Hello WORLD!");
  120. 目标字符串 小写字符串
  121. 27.strtoupper(): 字符串转为大写
  122.     echo strtoupper("Hello WORLD!");
  123. 输出: 大写字符串
  124. 28.ucfirst(): 字符串首字母大写
  125.     echo ucfirst("hello world"); // Hello world
  126. 29.ucwords(): 字符串每个单词首字符转为大写
  127.     echo ucwords("hello world"); // Hello World
  128.  html标签关联:
  129. 30.htmlentities(): 把字符转为HTML实体
  130. ?
  131. 1
  132. 2
  133.  
  134. $str = "John & 'Adams'";
  135. echo htmlentities($str, ENT_COMPAT); // John & 'Adams'
  136.  
  137. 31.htmlspecialchars(): 预定义字符转html编码
  138. 32.nl2br(): \n转义为<br>标签
  139.     echo nl2br("One line.\nAnother line.");
  140. 输出: 处理后的字符串
  141. 33.strip_tags(): 剥去 HTMLXML 以及 PHP 的标签
  142.     echo strip_tags("Hello <b>world!</b>");  
  143. 34.addcslashes():在指定的字符前添加反斜线转义字符串中字符
  144. ?
  145. 1
  146. 2
  147. 3
  148.  
  149. $str = "Hello, my name is John Adams.";
  150. echo $str;
  151. echo addcslashes($str,'m');
  152.  
  153. 输入: 目标字符串|指定的特定字符或字符范围
  154. 35.stripcslashes(): 删除由addcslashes()添加的反斜线
  155.     echo stripcslashes("Hello, \my na\me is Kai Ji\m.");
  156.      // 目标字符串 Hello, my name is Kai Jim.
  157. 36.addslashes(): 指定预定义字符前添加反斜线
  158.     $str = "Who's John Adams?";
  159.  echo addslashes($str);
  160. 输出: 把目标串中的' " \和null进行转义处理
  161. 37.stripslashes(): 删除由addslashes()添加的转义字符
  162.     echo stripslashes("Who\'s John Adams?"); // 清除转义符号Who'John Adams?
  163. 38.quotemeta(): 在字符串中某些预定义的字符前添加反斜线
  164. ?
  165. 1
  166. 2
  167. 3
  168.  
  169. $str = "Hello world. (can you hear me?)";
  170. echo quotemeta($str);
  171.  // Hello world\. \(can you hear me\?\)
  172.  
  173. 39.chr(): 从指定的 ASCII 值返回字符
  174.     echo chr(052); // ASCII 值返回对应的字符
  175. 40.ord(): 返回字符串第一个字符的ASCII
  176.     echo ord("hello"); 字符串第一个字符的 ASCII 
  177.  字符串比较:
  178. 41.strcasecmp(): 不区分大小写比较两字符串
  179.     echo strcasecmp("Hello world!","HELLO WORLD!");
  180. 输入: 两个目标字符串 输出: 1|等0|小 -1
  181. 42.strcmp(): 区分大小写比较两字符串
  182. 43.strncmp(): 比较字符串前n个字符,区分大小写
  183. 调用: int strncmp ( string $str1 , string $str2 , int $len)  
  184.  44.strncasecmp(): 比较字符串前n个字符,不区分大小写
  185. 调用: int strncasecmp ( string $str1 , string $str2 , int $len )
  186. 45.strnatcmp(): 自然顺序法比较字符串长度,区分大小写
  187. 调用: int strnatcmp ( string $str1 , string $str2 )
  188. 输入: 目标字符串 
  189. 46.strnatcasecmp(): 自然顺序法比较字符串长度, 不区分大小写
  190. 调用: int strnatcasecmp ( string $str1 , string $str2 )
  191. 字符串切割与拼接:
  192. 47.chunk_split():将字符串分成小块
  193. 调用: str chunk_split(str $body[,int $len[,str $end]])
  194. 输入: $body目标字串, $len长度, $str插入结束符 输出: 分割后的字符串
  195. 48.strtok(): 切开字符串
  196. 调用: str strtok(str $str,str $token)
  197. 目标字符串$str,以$token为标志切割返回切割后的字符串
  198. 49.explode(): 使用一个字符串为标志分割另一个字符串
  199. 调用: array explode(str $sep,str $str[,int $limit])
  200. 输入: $sep为分割符,$str目标字符串,$limit返回数组最多包含元素数 输出: 字符串被分割后形成的数组
  201. 50.implode(): join,将数组值用预订字符连接成字符串
  202. 调用: string implode ( string $glue , array $pieces )
  203. $glue默认, ''则直接相连
  204. 51.substr(): 截取字符串
  205. 调用: string substr ( string $string , int $start [, int $length ] )
  206. 字符串查找替换:
  207. 52.str_replace(): 字符串替换操作,区分大小写
  208. 调用mix str_replace(mix $search,mix $replace, mix $subject[,int &$num])
  209. 输入: $search查找的字符串,$replace替换的字符串,$subject被查找字串, &$num 输出: 返回替换后的结果
  210. 53.str_ireplace() 字符串替换操作,不区分大小写
  211. 调用: mix str_ireplace ( mix $search , mix $replace , mix $subject [, int &$count ] )
  212. 输入: $search查找的字符串,$replace替换的字符串,$subject被查找字串,&$num 输出: 返回替换后的结果
  213. 54.substr_count(): 统计一个字符串,在另一个字符串中出现次数
  214. 调用: int substr_count ( string $haystack , string $needle[, int $offset = 0 [, int $length ]] )
  215. 55.substr_replace(): 替换字符串中某串为另一个字符串
  216. 调用: mixed substr_replace ( mixed $string, string $replacement,int $start [, int $length ] )
  217. 56.similar_text(): 返回两字符串相同字符的数量
  218. 调用: int similar_text(str $str1,str $str2)
  219. 输入: 两个比较的字符串
  220. 输出: 整形,相同字符数量
  221. 57.strrchr(): 返回一个字符串在另一个字符串中最后一次出现位置开始到末尾的字符串
  222. 调用: string strrchr ( string $haystack , mixed $needle )
  223. 58.strstr(): 返回一个字符串在另一个字符串中开始位置到结束的字符串
  224. 调用: string strstr ( string $str, string $needle , bool $before_needle )   
  225.  59.strchr(): strstr()的别名,返回一个字符串在另一个字符串中首次出现的位置开始到末尾的字符串
  226. 调用: string strstr ( string $haystack , mixed $needle [, bool $before_needle = false ] )   
  227. 60.stristr(): 返回一个字符串在另一个字符串中开始位置到结束的字符串,不区分大小写
  228. 调用:string stristr ( string $haystack , mixed $needle [, bool $before_needle = false ] )
  229. 61.strtr(): 转换字符串中的某些字符
  230. 调用: string strtr ( string $str , string $from , string $to )
  231. 62.strpos(): 寻找字符串中某字符最先出现的位置
  232. 调用: int strpos ( string $haystack , mixed $needle [, int $offset = 0 ] )
  233. 63.stripos(): 寻找字符串中某字符最先出现的位置,不区分大小写 调用: int stripos ( string $haystack , string $needle [, int $offset ] )
  234. 64.strrpos(): 寻找某字符串中某字符最后出现的位置
  235. 调用: int strrpos ( string $haystack , string $needle [, int $offset = 0 ] )
  236. 65.strripos(): 寻找某字符串中某字符最后出现的位置,不区分大小写
  237. 调用: int strripos ( string $haystack , string $needle [, int $offset ] )
  238. 66.strspn(): 返回字符串中首次符合mask的子字符串长度 调用: int strspn ( string $str1 , string $str2 [, int $start [, int $length ]] )
  239. 67.strcspn(): 返回字符串中不符合mask的字符串的长度
  240. 调用: int strcspn ( string $str1 , string $str2 [, int $start [, int $length ]] )
  241. 输入: $str1被查询,$str2查询字符串,$start开始查询的字符,$length是查询长度 输出: 返回从开始到第几个字符
  242. 字符串统计:
  243. 68.str_word_count(): 统计字符串含有的单词数
  244. 调用: mix str_word_count(str $str,[])
  245. 输入: 目标字符串 输出: 统计处的数量
  246. 69.strlen(): 统计字符串长度int strlen(str $str)
  247. 输入: 目标字符串 输出:整型长度
  248. 70.count_chars(): 统计字符串中所有字母出现次数(0..255) 调用: mixed count_chars ( string $string [, int $mode ] )
  249. 字符串编码:
  250. 71.md5(): 字符串md5编码
  251. ?
  252. 1
  253. 2
  254.  
  255. $str = "Hello";
  256. echo md5($str);
  257.  
  258. 数组函数
  259. 数组创建:
  260. 72.array(): 生成一个数组
  261. ?
  262. 1
  263. 2
  264.  
  265. $a=array("Dog","Cat","Horse");
  266. print_r($a);
  267.  
  268. 数组值或,键=>值一个数组型变量
  269. 73.array_combine(): 生成一个数组,用一个数组的值 作为键名,另一个数组值作为值
  270.     $a1=array("a","b","c","d");
  271.      $a2=array("Cat","Dog","Horse","Cow");
  272.      print_r(array_combine($a1,$a2));
  273.  $a1为提供键,$a2提供值合成后的数组
  274. 74.range(): 创建并返回一个包含指定范围的元素的数组。
  275.     $number = range(0,50,10);
  276.      print_r ($number);
  277. 输入: 0是最小值,50是最大值,10是步长 输出: 合成后的数组
  278. 75.compact(): 创建一个由参数所带变量组成的数组
  279. ?
  280. 1
  281. 2
  282. 3
  283. 4
  284. 5
  285. 6
  286.  
  287. $firstname = "Peter";
  288. $lastname = "Griffin";
  289. $age = "38";
  290. $result = compact("firstname", "lastname",
  291. "age");
  292. print_r($result);
  293.  
  294. 变量或数组
  295. 返回由变量名为键,变量值为值的数组,变量也可以为多维数组.会递归处理 76.array_fill(): 用给定的填充(值生成)数组
  296. ?
  297. 1
  298. 2
  299.  
  300. $a=array_fill(2,3,"Dog");
  301. print_r($a);
  302.  
  303. 2是键,3是填充的数量,'Dog'为填充内容返回完成的数组
  304. 数组合并和拆分:    
  305. 77.array_chunk(): 把一个数组分割为新的数组块
  306. ?
  307. 1
  308. 2
  309.  
  310. $a=array("a"=>"Cat","b"=>"Dog","c"=>"Horse","d"=>"Cow");
  311. print_r(array_chunk($a,2));
  312.  
  313. 一个数组分割后的多维数组,规定每个新数组包含2个元素
  314. 78.array_merge(): 把两个或多个数组合并为一个数组。
  315. ?
  316. 1
  317. 2
  318. 3
  319.  
  320. $a1=array("a"=>"Horse","b"=>"Dog");
  321. $a2=array("c"=>"Cow","b"=>"Cat");
  322. print_r(array_merge($a1,$a2));
  323.  
  324. 输入: 两个数组 输出: 返回完成后的数组
  325. 79.array_slice(): 在数组中根据条件取出一段值,并返回。
  326. ?
  327. 1
  328. 2
  329.  
  330. $a=array(0=>"Dog",1=>"Cat",2=>"Horse",3=>"Bird");
  331. print_r(array_slice($a,1,2));
  332.  
  333. 输入: 一个数组 输出: 1为从'Cat'开始,2为返回两个元素
  334. 数组比较:
  335. 80.array_diff(): 返回两个数组的差集数组
  336. ?
  337. 1
  338. 2
  339. 3
  340.  
  341. $a1=array(0=>"Cat",1=>"Dog",2=>"Horse");
  342. $a2=array(3=>"Horse",4=>"Dog",5=>"Fish");
  343.  print_r(array_diff($a1,$a2)); //返回'Cat'
  344.  
  345. 输入: 两个或多个数组 输出: $a1$a2的不同之处
  346. 81.array_intersect(): 返回两个或多个数组的交集数组 输出: 返回'Dog''Horse',$a1$a2的相同之处
  347. 数组查找替换:     
  348. 82.array_search(): 在数组中查找一个值,返回一个键,没有返回返回假
  349. ?
  350. 1
  351. 2
  352.  
  353. $a=array("a"=>"Dog","b"=>"Cat","c"=>"Horse");
  354. echo array_search("Dog",$a);
  355.  
  356. 输入: 一个数组 输出: 成功返回键名,失败返回false
  357. 83.array_splice(): 把数组中一部分删除用其他值替代
  358. ?
  359. 1
  360. 2
  361. 3
  362. 4
  363.  
  364. $a1=array(0=>"Dog",1=>"Cat",2=>"Horse",3=>"Bird");
  365. $a2=array(0=>"Tiger",1=>"Lion");
  366. array_splice($a1,0,2,$a2);
  367. print_r($a1);
  368.  
  369. 输入: 一个或多个数组 输出: $a1被移除的部分由$a2补全
  370. 84.array_sum(): 返回数组中所有值的总和
  371. ?
  372. 1
  373. 2
  374.  
  375. $a=array(0=>"5",1=>"15",2=>"25");
  376. echo array_sum($a);
  377.  
  378. 输入: 一个数组 输出: 返回和
  379. 85.in_array(): 在数组中搜索给定的值,区分大小写
  380. ?
  381. 1
  382. 2
  383. 3
  384. 4
  385. 5
  386. 6
  387. 7
  388.  
  389. $people = array("Peter", "Joe", "Glenn", "Cleveland");
  390. if (in_array("Glenn",$people) {
  391. echo "Match found";
  392. }
  393. else{
  394. echo "Match not found";
  395. }
  396.  
  397. 输入: 需要搜索的值|数组 输出: true/false
  398. 86.array_key_exists(): 判断某个数组中是否存在指定的 key
  399. 输入: 需要搜索的键名|数组
  400. 数组指针操作:
  401. 87.key(): 返回数组内部指针当前指向元素的键名    
  402. 88.current(): 返回数组中的当前元素(单元).    
  403. 89.next(): 把指向当前元素的指针移动到下一个元素的位置,并返回当前元素的值    
  404. 90.prev(): 把指向当前元素的指针移动到上一个元素的位置,并返回当前元素的值    
  405. 91.end(): 将数组内部指针指向最后一个元素,并返回该元素的值(如果成功)     
  406. 92.reset(): 把数组的内部指针指向第一个元素,并返回这个元素的值     
  407. 93.list(): 用数组中的元素为一组变量赋值
  408. ?
  409. 1
  410. 2
  411.  
  412. $my_array=array("Dog","Cat","Horse");
  413. list($a, $b, $c) = $my_array;
  414.  
  415. 输入: $a, $b, $c为需要赋值的变量 输出: 变量分别匹配数组中的值
  416. 94.array_shift(): 删除数组中的第一个元素,并返回被删除元素的值
  417. ?
  418. 1
  419. 2
  420. 3
  421.  
  422. $a=array("a"=>"Dog","b"=>"Cat","c"=>"Horse");
  423. echo array_shift($a);
  424. print_r ($a);
  425.  
  426. 95.array_unshift(): 在数组开头插入一个或多个元素
  427. ?
  428. 1
  429. 2
  430. 3
  431.  
  432. $a=array("a"=>"Cat","b"=>"Dog");
  433. array_unshift($a,"Horse");
  434. print_r($a);
  435.  
  436. 96.array_push(): 向数组最后压入一个或多个元素
  437. ?
  438. 1
  439. 2
  440. 3
  441.  
  442. $a=array("Dog","Cat");
  443. array_push($a,"Horse","Bird");
  444. print_r($a);
  445.  
  446. 输入: 目标数组|需要压入的值 返回值: 返回新的数组
  447. 97.array_pop(): 取得(删除)数组中的最后一个元素
  448. ?
  449. 1
  450. 2
  451. 3
  452.  
  453. $a=array("Dog","Cat","Horse");
  454. array_pop($a);
  455. print_r($a);
  456.  
  457. 输入: $a为目标数组 输出: 返回数组剩余元素
  458. 数组键值操作:     
  459. 98.shuffle(): 将数组打乱,保留键名
  460. ?
  461. 1
  462. 2
  463. 3
  464.  
  465. $my_array = array("a" => "Dog", "b" => "Cat");
  466. shuffle($my_array);
  467. print_r($my_array);
  468.  
  469. 输入: 一个或多个数组 输出: 顺序打乱后的数组
  470. 99.count(): 计算数组中的单元数目或对象中的属性个数
  471. ?
  472. 1
  473. 2
  474. 3
  475. 4
  476.  
  477. $people = array("Peter", "Joe", "Glenn",
  478. "Cleveland");
  479. $result = count($people);
  480. echo $result;
  481.  
  482. 输入: 数组 输出: 输出元素个数
  483. 100.array_flip(): 返回一个键值反转后的数组
  484. ?
  485. 1
  486. 2
  487.  
  488. $a=array(0=>"Dog",1=>"Cat",2=>"Horse");
  489. print_r(array_flip($a));
  490.  
  491. 输出: 返回完成后的数组 101.array_keys(): 返回数组所有的键,组成一个数组
  492. ?
  493. 1
  494. 2
  495.  
  496. $a=array("a"=>"Horse","b"=>"Cat","c"=>"Dog");
  497. print_r(array_keys($a));
  498.  
  499. 输出: 返回由键名组成的数组
  500. 102.array_values(): 返回数组中所有值,组成一个数组
  501. 输出: 返回由键值组成的数组
  502. 103.array_reverse(): 返回一个元素顺序相反的数组 元素顺序相反的一个数组,键名和键值依然匹配
  503. 104.array_count_values(): 统计数组中所有的值出现的次数
  504. ?
  505. 1
  506. 2
  507.  
  508. $a=array("Cat","Dog","Horse","Dog");
  509. print_r(array_count_values($a));
  510.  
  511. 输出: 返回数组原键值为新键名,次数为新键值
  512. 105.array_rand(): 从数组中随机抽取一个或多个元素,注意是键名!!!
  513. ?
  514. 1
  515. 2
  516.  
  517. $a=array("a"=>"Dog","b"=>"Cat","c"=>"Horse");
  518. print_r(array_rand($a,1));
  519.  
  520. $a为目标数组, 1为抽取第几个元素的键名返回第1个元素的键名b
  521. 106.each(): 返回数组中当前的键/值对并将数组指针向前移动一步 调用array each ( array &$array )
  522. 在执行 each() 之后,数组指针将停留在数组中的下一个单元或者当碰到数组结尾时停留在最后一个单元。如果要再用 each 遍历数组,必须使用 reset()。
  523. 返回值: 数组中当前指针位置的键/值对并向前移动数组指针。键值对被返回为四个单元的数组,键名为01key value。单元 0  key 包含有数组单元的键名,1  value 包含有数据。 如果内部指针越过了数组的末端,则 each() 返回 FALSE
  524. 107.array_unique(): 删除重复值,返回剩余数组
  525. ?
  526. 1
  527. 2
  528.  
  529. $a=array("a"=>"Cat","b"=>"Dog","c"=>"Cat");
  530. print_r(array_unique($a));
  531.  
  532. 输入: 数组 输入: 返回无重复值数组,键名不变
  533. 数组排序:   
  534. 108.sort(): 按升序对给定数组的值排序,不保留键名
  535. ?
  536. 1
  537. 2
  538. 3
  539. 4
  540.  
  541. $my_array = array("a" => "Dog", "b" => "Cat",
  542. "c" => "Horse");
  543. sort($my_array);
  544. print_r($my_array);
  545.  
  546. 输出: true/false   109.rsort(): 对数组逆向排序,不保留键名   110.asort(): 对数组排序,保持索引关系    111.arsort(): 对数组逆向排序,保持索引关  112.ksort(): 系按键名对数组排序  113.krsort(): 将数组按照键逆向排序 114.natsort(): 用自然顺序算法对数组中的元素排序     115.natcasesort(): 自然排序,不区分大小写      
  547. 文件系统函数
  548. 116.fopen(): 打开文件或者 URL
  549.     $handle = fopen("ftp://user:password@example.com/somefile.txt", "w");
  550. 调用: resource fopen ( string filename, string mode [, bool use_include_path [, resource zcontext]] )
  551. 返回值: 如果打开失败,本函数返回 FALSE
  552. 117.fclose(): 关闭一个已打开的文件指针
  553. ?
  554. 1
  555. 2
  556. 3
  557.  
  558. $handle = fopen('somefile.txt', 'r');
  559. fclose($handle);
  560. bool fclose(resource handle)
  561.  
  562. 输出: 如果成功则返回 TRUE,失败则返回 FALSE
  563. 文件属性
  564. 118.file_exists(): 检查文件或目录是否存在
  565. ?
  566. 1
  567. 2
  568. 3
  569. 4
  570. 5
  571. 6
  572.  
  573. $filename = '/path/to/foo.txt';
  574. if (file_exists($filename)) {
  575. echo "exists";
  576. } else {
  577. echo "does not exist";
  578. }
  579.  
  580. 调用: bool file_exists ( string filename ) 输入: 指定的文件或目录 输出: 存在则返回 TRUE,否则返回 FALSE
  581. 119.filesize(): 取得文件大小
  582. ?
  583. 1
  584. 2
  585.  
  586. $filename = 'somefile.txt';
  587. echo $filename . ': ' . filesize($filename) .'bytes';
  588.  
  589. 调用: int filesize ( string $filename )
  590. 输出: 返回文件大小的字节数,如果出错返回 FALSE 并生成一条 E_WARNING 级的错误
  591. 120.is_readable(): 判断给定文件是否可读
  592. ?
  593. 1
  594. 2
  595. 3
  596. 4
  597. 5
  598. 6
  599.  
  600. $filename = 'test.txt';
  601. if (is_readable($filename)) {
  602. echo '可读';
  603. } else {
  604. echo '不可读';
  605. }
  606.  
  607. 调用: bool is_readable ( string $filename ) 输出: 如果由 filename指定的文件或目录存在并且可读则返回 TRUE
  608. 121.is_writable(): 判断给定文件是否可写
  609. ?
  610. 1
  611. 2
  612. 3
  613. 4
  614. 5
  615. 6
  616.  
  617. $filename = 'test.txt';
  618. if (is_writable($filename)) {
  619. echo '可写';
  620. } else {
  621. echo '不可写';
  622. }
  623.  
  624. 调用: bool is_writable ( string $filename ) filename 参数 可以是一个允许进行是否可写检查的目录名
  625. 输出: 如果文件存在并且可写则返回 TRUE
  626. 122.is_executable(): 判断给定文件是否可执行
  627. ?
  628. 1
  629. 2
  630. 3
  631. 4
  632. 5
  633. 6
  634.  
  635. $file = 'setup.exe';
  636. if (is_executable($file)) {
  637. echo '可执行';
  638. } else {
  639. echo '不可执行';
  640. }
  641.  
  642. 调用: bool is_executable ( string $filename ) 输出: 如果文件存在且可执行则返回 TRUE
  643. 123.filectime(): 获取文件的创建时间
  644.  
  645. ?
  646. 1
  647. 2
  648.  
  649. $filename = 'somefile.txt';
  650. echo filectime($filename);
  651.  
  652. 调用: int filectime ( string $filename ) 输出: 时间以 Unix 时间戳的方式返回,如果出错则返回FALSE
  653. 124.filemtime(): 获取文件的修改时间
  654. ?
  655. 1
  656. 2
  657.  
  658. $filename = 'somefile.txt';
  659. echo filemtime($filename);
  660.  
  661.     int filemtime ( string $filename )
  662. 输出: 返回文件上次被修改的时间,出错时返回 FALSE。时间以 Unix时间戳的方式返回
  663. 125.fileatime(): 获取文件的上次访问时间
  664. ?
  665. 1
  666. 2
  667.  
  668. $filename = 'somefile.txt';
  669. echo fileatime($filename);
  670.  
  671. 调用: int fileatime (string $filename)
  672. 输出: 返回文件上次被访问的时间, 如果出错则返回FALSE. 时间以Unix时间戳的方式返回.
  673. 126.stat(): 获取文件大部分属性值
  674. ?
  675. 1
  676. 2
  677.  
  678. $filename = 'somefile.txt';
  679. var_dump(fileatime($filename));
  680.  
  681. 调用: array stat (string $filename 输出: 返回由 filename 指定的文件的统计信息
  682. 文件操作
  683. 127.fwrite(): 写入文件
  684. ?
  685. 1
  686. 2
  687. 3
  688. 4
  689. 5
  690.  
  691. $filename = 'test.txt';
  692. $somecontent = "添加这些文字到文件\n";
  693. $handle = fopen($filename, 'a');
  694. fwrite($handle, $somecontent);
  695. fclose($handle);
  696.  
  697. 调用: int fwrite ( resource handle, string string [, int length] )
  698. 输出:  string 的内容写入 文件指针 handle 处。如果指定了 length,当写入了length个字节或者写完了string以后,写入就会停止, 视乎先碰到哪种情况
  699. 128.fputs(): 同上     
  700. 129.fread(): 读取文件
  701. ?
  702. 1
  703. 2
  704. 3
  705. 4
  706.  
  707. $filename = "/usr/local/something.txt";
  708. $handle = fopen($filename, "r");
  709. $contents = fread($handle, filesize($filename));
  710.  fclose($handle);
  711.  
  712. 调用: string fread ( int handle, int length ) 从文件指针handle,读取最多 length 个字节
  713. 130.feof(): 检测文件指针是否到了文件结束的位置
  714. ?
  715. 1
  716. 2
  717. 3
  718. 4
  719.  
  720. $file = @fopen("no_such_file", "r");
  721. while (!feof($file)) {
  722. }
  723. fclose($file);
  724.  
  725. 调用: bool feof ( resource handle ) 输出: 如果文件指针到了 EOF 或者出错时则返回TRUE,否则返回一个错误(包括 socket 超时),其它情况则返回 FALSE
  726. 131.fgets(): 从文件指针中读取一行
  727. ?
  728. 1
  729. 2
  730. 3
  731. 4
  732. 5
  733. 6
  734. 7
  735. 8
  736.  
  737. $handle = @fopen("/tmp/inputfile.txt", "r");
  738. if ($handle) {
  739. while (!feof($handle)) {
  740. $buffer = fgets($handle, 4096);
  741. echo $buffer;
  742. }
  743. fclose($handle);
  744. }
  745.  
  746. 调用: string fgets ( int handle [, int length] ) 输出: handle指向的文件中读取一行并返回长度最多为length-1字节的字符串.碰到换行符(包括在返回值中)、EOF 或者已经读取了length -1字节后停止(看先碰到那一种情况). 如果没有指定 length,则默认为1K, 或者说 1024 字节.
  747. 132.fgetc(): 从文件指针中读取字符
  748. ?
  749. 1
  750. 2
  751. 3
  752. 4
  753. 5
  754. 6
  755. 7
  756.  
  757. $fp = fopen('somefile.txt', 'r');
  758. if (!$fp) {
  759. echo 'Could not open file somefile.txt';
  760. }
  761. while (false !== ($char = fgetc($fp))) {
  762. echo "$char\n";
  763. }
  764.  
  765. 输入: string fgetc ( resource $handle ) 输出: 返回一个包含有一个字符的字符串,该字符从 handle指向的文件中得到. 碰到 EOF 则返回 FALSE.
  766. 133.file(): 把整个文件读入一个数组中
  767. ?
  768. 1
  769. 2
  770. 3
  771. 4
  772. 5
  773. 6
  774. 7
  775. 8
  776. 9
  777. 10
  778.  
  779. $lines = file('http://www.example.com/');
  780. // 在数组中循环,显示 HTML 的源文件并加上行号。
  781.  
  782.  foreach ($lines as $line_num => $line) {
  783.  echo "Line #<b>{$line_num}</b> : " .
  784.  htmlspecialchars($line) . "<br />\n";
  785.  }
  786. // 另一个例子将 web 页面读入字符串。参见 file_get_contents()。
  787.  
  788.  $html = implode('', file('http://www.example.com/'));
  789.  
  790. 调用: array file ( string $filename [, int $use_include_path [, resource $context ]] )
  791. 输出: 数组中的每个单元都是文件中相应的一行,包括换行符在内。如果失败 file() 返回 FALSE
  792. 134.readfile(): 输出一个文件  调用: int readfile ( string $filename [, bool $use_include_path [, resource $context ]] )
  793. 输出: 读入一个文件并写入到输出缓冲。返回从文件中读入的字节数。如果出错返回 FALSE
  794. 135.file_get_contents(): 将整个文件读入一个字符串
  795.     echo file_get_contents('http://www.baidu.com');
  796. 调用: string file_get_contents ( string $filename [, bool $use_include_path [, resource $context [, int $offset [, int $maxlen ]]]] )   136.file_put_contents():将一个字符串写入文件
  797.     file_put_contents('1.txt','aa');
  798. 调用: int file_put_contents ( string $filename , string $data [, int $flags [, resource $context ]] )
  799. 输出: 该函数将返回写入到文件内数据的字节数
  800. 137.ftell(): 返回文件指针读/写的位置
  801. ?
  802. 1
  803. 2
  804. 3
  805. 4
  806. 5
  807.  
  808. $fp=fopen('tx.txt','r');
  809. fseek($fp,10);
  810. echo ftell($fp);
  811. fread($fp,4);
  812. echo ftell($fp);
  813.  
  814. 调用: int ftell ( resource $handle ) 输出: 返回由 handle 指定的文件指针的位置,也就是文件流中的偏移量
  815. 138.fseek(): 在文件指针中定位
  816. ?
  817. 1
  818. 2
  819. 3
  820. 4
  821. 5
  822.  
  823. $fp=fopen('tx.txt','r');
  824. fseek($fp,10);
  825. echo ftell($fp);
  826. fread($fp,4);
  827. echo ftell($fp);
  828.  
  829. 调用: int fseek ( resource $handle , int $offset [, int $whence ] ) 输出: 成功则返回 0;否则返回 -1
  830. 139.rewind(): 倒回文件指针的位置
  831. ?
  832. 1
  833. 2
  834. 3
  835. 4
  836. 5
  837. 6
  838.  
  839. $fp=fopen('tx.txt','r');
  840. fseek($fp,3);
  841. echo ftell($fp);
  842. fread($fp,4);
  843. rewind($fp);
  844. echo ftell($fp);
  845.  
  846. 调用: bool rewind ( resource $handle ) 返回值: 如果成功则返回 TRUE,失败则返回 FALSE
  847. 140.flock(): 轻便的执行文件锁定
  848. ?
  849. 1
  850. 2
  851. 3
  852. 4
  853. 5
  854. 6
  855.  
  856. $fp=fopen('tx.txt','r');
  857. flock($fp, LOCK_SH);//共享锁
  858. //flock($fp, LOCK_EX);//独立锁,写文件时用它打开
  859. //flock($fp, LOCK_NB);//附加锁
  860. flock($fp, LOCK_UN);//释放锁
  861. fclose($fp);
  862.  
  863. 调用: bool flock ( int $handle , int $operation [, int &$wouldblock ] ) 输出: 如果成功则返回 TRUE,失败则返回 FALSE
  864. 目录
  865. 141.basename(): 返回路径中的文件名部分
  866. ?
  867. 1
  868. 2
  869. 3
  870.  
  871. path = "/home/httpd/html/index.php";
  872. $file = basename($path);
  873. $file = basename($path,".php");
  874.  
  875. 调用: string basename ( string $path [, string $suffix ]) 输出: 给出一个包含有指向一个文件的全路径的字符串,本函数返回基本的文件名。如果文件名是以 suffix  束的,那这一部分也会被去掉
  876. 142.dirname(): 返回路径中的目录部分
  877. ?
  878. 1
  879. 2
  880.  
  881. $path = "/etc/passwd";
  882. $file = dirname($path);
  883.  
  884. 调用: string dirname ( string $path ) 输出: 给出一个包含有指向一个文件的全路径的字符串,本函数返回去掉文件名后的目录名
  885. 143.pathinfo(): 返回文件路径的信息
  886. ?
  887. 1
  888. 2
  889. 3
  890.  
  891. echo '<pre>';
  892. print_r(pathinfo("/www/htdocs/index.html"));
  893. echo '</pre>';
  894.  
  895. 调用: mixed pathinfo ( string $path [, int $options ] ) 返回一个关联数组包含有 path 的信息
  896. 144.opendir(): 打开目录句柄
  897. ?
  898. 1
  899. 2
  900. 3
  901.  
  902. $fp=opendir('E:/xampp/htdocs/php/study/19');
  903. echo readdir($fp);
  904. closedir($fp);
  905.  
  906. 调用: resource opendir ( string $path [, resource $context ] ) 返回值: 如果成功则返回目录句柄的 resource,失败则返回FALSE
  907. 145.readdir(): 从目录句柄中读取条目
  908. ?
  909. 1
  910. 2
  911. 3
  912.  
  913. $fp=opendir('E:/xampp/htdocs/php/study/19');
  914. echo readdir($fp);
  915. closedir($fp);
  916.  
  917. 调用: string readdir ( resource $dir_handle ) 返回值: 返回目录中下一个文件的文件名。文件名以在文件系统中的排序返回
  918. 146.closedir(): 关闭目录句柄
  919. ?
  920. 1
  921. 2
  922. 3
  923.  
  924. $fp=opendir('E:/xampp/htdocs/php/study/19');
  925. echo readdir($fp);
  926. closedir($fp);
  927.  
  928. 调用: void closedir ( resource $dir_handle ) 关闭由 dir_handle 指定的目录流。流必须之前被opendir() 所打开 147.rewinddir() : 倒回目录句柄
  929.  
  930. ?
  931. 1
  932. 2
  933. 3
  934. 4
  935. 5
  936. 6
  937. 7
  938.  
  939. $fp=opendir('E:/xampp/htdocs/php/study/19');
  940. echo readdir($fp).'<br />';
  941. echo readdir($fp).'<br />';
  942. echo readdir($fp).'<br />';
  943. rewinddir($fp);
  944. echo readdir($fp).'<br />';
  945. closedir($fp);
  946.  
  947. 调用: void rewinddir ( resource $dir_handle ) 输出:  dir_handle 指定的目录流重置到目录的开头 148.mkdir(): 新建目录
  948.     mkdir('123');
  949. 调用: bool mkdir ( string $pathname [, int $mode [, bool $recursive [, resource $context ]]] ) 输出: 尝试新建一个由 pathname 指定的目录
  950. 149.rmdir(): 删除目录
  951.     rmdir('123');
  952. 调用: bool rmdir ( string $dirname ) 输出: 尝试删除 dirname 所指定的目录。目录必须是空的,而且要有相应的权限。如果成功则返回TRUE,失败则返回 FALSE
  953. 150.unlink(): 删除文件
  954. ?
  955. 1
  956. 2
  957.  
  958. unlink('123/1.txt');
  959. rmdir('123');
  960.  
  961. 调用: bool unlink ( string $filename ) 输出: 删除 filename 。和 Unix C  unlink() 函数相似。如果成功则返回 TRUE,失败则返回 FALSE
  962. 151.copy(): 拷贝文件
  963.     copy('index.php','index.php.bak');
  964. 调用: bool copy ( string $source , string $dest ) 输出: 将文件从 source 拷贝到 dest. 如果成功则返回TRUE,失败则返回 FALSE
  965. 152.rename(): 重命名一个文件或目录
  966.     rename('tx.txt','txt.txt');
  967. 调用: bool rename ( string $oldname , string $newname [, resource $context ] ) 输出: 如果成功则返回 TRUE,失败则返回 FALSE
  968. 文件的上传与下载
  969. 153.is_uploaded_file():判断文件是否是通过 HTTP POST上传的
  970. ?
  971. 1
  972. 2
  973. 3
  974. 4
  975. 5
  976. 6
  977. 7
  978. 8
  979. 9
  980. 10
  981.  
  982. if(is_uploaded_file($_FILES['bus']['tmp_name'])){
  983. if( move_uploaded_file($_FILES['bus']['tmp_name'],
  984. $NewPath) ){
  985. echo '上传成功<br /><img src="'.$NewPath.'">';
  986. }else{
  987. exit('失败');
  988. }
  989. }else{
  990. exit('不是上传文件');
  991. }
  992.  
  993. 调用: bool is_uploaded_file ( string $filename )  
  994. 154.move_uploaded_file(): 将上传的文件移动到新位置
  995. ?
  996. 1
  997. 2
  998. 3
  999. 4
  1000. 5
  1001. 6
  1002. 7
  1003. 8
  1004. 9
  1005. 10
  1006.  
  1007. if(is_uploaded_file($_FILES['bus']['tmp_name'])){
  1008. if( move_uploaded_file($_FILES['bus']['tmp_name'],
  1009. $NewPath) ){
  1010. echo '上传成功<br /><img src="'.$NewPath.'">';
  1011. }else{
  1012. exit('失败');
  1013. }
  1014. }else{
  1015. exit('不是上传文件');
  1016. }
  1017.  
  1018. 调用: bool move_uploaded_file ( string $filename , string
  1019. 时间函数
  1020. 155.time(): 返回当前的 Unix 时间戳time(); 调用: int time ( void ) 输出: 返回自从 Unix 纪元(格林威治时间 1970  1  1  00:00:00)到当前时间的秒数
  1021. 156.mktime(): 取得一个日期的 Unix 时间戳
  1022.     mktime(0, 0, 0, 4, 25, 2012);
  1023. 调用: int mktime ([ int $hour [, int $minute [, int $second [, int $month [, int $day [, int $year [, int $is_dst ]]]]]]] )   156.date(): 格式化一个本地时间/日期
  1024. date('Y年m月d日 H:i:s');
  1025. 调用: string date ( string $format [, int $timestamp ] )
  1026. 输出: 20160910 20:45:54
  1027. 157.checkdate(): 验证一个格里高里日期 调用: bool checkdate ( int $month , int $day , int $year) 输出: 如果给出的日期有效则返回 TRUE,否则返回 FALSE
  1028. ?
  1029. 1
  1030. 2
  1031. 3
  1032. 4
  1033. 5
  1034.  
  1035. if(checkdate(6,31,2012)){
  1036. echo '成立';
  1037. }else{
  1038. echo '不成立';
  1039. }
  1040.  
  1041. 158.date_default_timezone_set(): 设定用于一个脚本中所有日期时间函数的默认时区
  1042.     date_default_timezone_set('PRC');
  1043. 调用: bool date_default_timezone_set ( string $timezone_identifier)
  1044. 返回值: 如果 timezone_identifier 参数无效则返回 FALSE,否则返回 TRUE
  1045. 159.getdate(): 取得日期/时间信息 调用: array getdate ([ int $timestamp ] )
  1046. 输出: 返回一个根据timestamp得出的包含有日期信息的关联数组。如果没有给出时间戳则认为是当前本地时间
  1047. ?
  1048. 1
  1049. 2
  1050.  
  1051. $t=getdate();
  1052. var_dump($t);
  1053.  
  1054. 160.strtotime(): 将任何英文文本的日期时间描述解析为 Unix 时间戳
  1055. ?
  1056. 1
  1057. 2
  1058. 3
  1059. 4
  1060. 5
  1061. 6
  1062. 7
  1063. 8
  1064.  
  1065. echo strtotime("now");
  1066. int strtotime ( string $time [, int $now ] )  
  1067. echo strtotime("10 September 2000");
  1068. echo strtotime("+1 day");
  1069. echo strtotime("+1 week");
  1070. echo strtotime("+1 week 2 days 4 hours 2 seconds");
  1071. echo strtotime("next Thursday");
  1072. echo strtotime("last Monday");
  1073.  
  1074. 161.microtime(): 返回当前 Unix 时间戳和微秒数 调用: mixed microtime ([ bool $get_as_float ] )
  1075. ?
  1076. 1
  1077. 2
  1078. 3
  1079. 4
  1080.  
  1081. $start=microtime(true);
  1082. sleep(3);
  1083. $stop=microtime(true);
  1084. echo $stop-$start;
  1085.  
  1086. 其他常用:
  1087. 162.intval(): 获取变量的整数值 调用: int intval ( mixed $var [, int $base = 10 ] ) 通过使用指定的进制 base 转换(默认是十进制),返回变量 var  integer 数值。 intval() 不能用于 object,否则会产生 E_NOTICE 错误并返回 1
  1088. var: 要转换成 integer 的数量值
  1089. base: 转化所使用的进制
  1090. 返回值: 成功时返回 var  integer 值,失败时返回 0 空的 array 返回 0,非空的 array 返回 1
  1091. PDO类的相关函数 prepare() execute() fetch()
  1092. ?
  1093. 1
  1094. 2
  1095. 3
  1096. 4
  1097. 5
  1098. 6
  1099. 7
  1100. 8
  1101. 9
  1102. 10
  1103. 11
  1104. 12
  1105. 13
  1106. 14
  1107. 15
  1108. 16
  1109. 17
  1110. 18
  1111. 19
  1112. 20
  1113. 21
  1114. 22
  1115. 23
  1116. 24
  1117. 25
  1118. 26
  1119. 27
  1120. 28
  1121. 29
  1122.  
  1123. <?php
  1124. $driver = 'mysql';
  1125. $database = "dbname=CODINGGROUND";
  1126. $dsn = "$driver:host=localhost;unix_socket=/home/cg/mysql/mysql.sock;$database";
  1127.  
  1128. $username = 'root';
  1129. $password = 'root';
  1130.  
  1131. try {
  1132.  $conn = new PDO($dsn, $username, $password);
  1133.  echo "<h2>Database CODINGGROUND Connected<h2>";
  1134. }catch(PDOException $e){
  1135.  echo "<h1>" . $e->getMessage() . "</h1>";
  1136. }
  1137. $sql = 'SELECT * FROM users';
  1138. $stmt = $conn->prepare($sql);
  1139. $stmt->execute();
  1140.  
  1141. echo "<table style='width:100%'>";
  1142. while($row = $stmt->fetch(PDO::FETCH_ASSOC)){
  1143.  echo "<tr>";
  1144.  foreach($row as $value)
  1145.  {
  1146.  echo sprintf("<td>%s</td>", $value);
  1147.  }
  1148.  echo "</tr>";
  1149. }
  1150. echo "</table>";
  1151. ?>
  1152.  
  1153. 正则表达式-元字符
  1154. 元字符及其匹配范围
  1155. \d 匹配任意一个十进制数字,等价于: [0-9] \D 匹配除十进制数字以外的任意数字,等价于: [^0-9] \s:匹配空白字符,等价于: [\n\f\r\t\v] \S: 匹配除空白字符以外的任意一个字符, 等价于[^\n\f\r\t\v]
  1156. \w 匹配任意一个数字、字母和下划线,等价于: [0-9a-zA-Z_] \W 匹配除字母、数字和下划线以外的任意字符, 等价于: [^0-9a-zA-Z_] [] 1)用来表示范围。2)匹配任意一个中括号中定义的原子   [^]: 中括号里面的^(抑扬符):表示匹配任意一个除中括号里面定义的原子
  1157. 限定次数
  1158. * 匹配0次、1次或多次其前的原子, 等价于: {
    0,} + 匹配1次或多次其前的原子, 等价于: {
    1,} ? 匹配0次或1次其前的原子, 等价于: {
    0,1} {
    n} 表示其前的原子正好出现n次, 等价于: {
    n,} 表示其前的原子至少出现n次,最多不限制   {
    m,n} 表示其前的原子最少出现m次,最多出现n  
  1159. 其它
  1160. . 匹配除换行符(\n)以外的任意字符【windows下还匹配\f\r】  | 两个或多个分支选择【优先级最低】 ^ 匹配输入字符的开始位置  匹配输入字符的结束位置  \b 匹配词边界  \B 匹配非词边界  () 1)模式单元,把多个小原子组成一个大原子。2)可以改变优先级

转载于:https://www.cnblogs.com/zhouwenwu/p/8667767.html

你可能感兴趣的文章
MySQL主从延迟分析
查看>>
android中的dumpsys命令
查看>>
switch-划分vlan
查看>>
android的编译和运行过程深入分析
查看>>
C++关于new动态分配内存的问题
查看>>
LINUX 下创建RAID5以及LVM磁盘配额
查看>>
Python queue
查看>>
通付盾安全加固——拓展安卓内核安全边界
查看>>
2012年度十大杰出IT博客之 丁虎强
查看>>
【ORACLE】ORACLE常用功能函数
查看>>
Console.WriteLine占位符的小知识点
查看>>
zabbix 安装使用手册(HA)-1
查看>>
find中mtime的+ - n
查看>>
LVS之偷懒脚本
查看>>
openssl工具详解及自建CA方法
查看>>
ftp匿名用户,虚拟用户,配置文件参数含义
查看>>
我的友情链接
查看>>
很多种QQ挂机方法
查看>>
mysql入门笔记1
查看>>
VM虚拟机添加硬盘
查看>>