php 二维数组排序使用详解
昨天要排序数组的时候发现了,要按时间排序,但是php并没有内设这个函数,所以在网上找到了这个代码,第一个参数为数组,第二个是要排序的元素,第三个为排序方式,
下面就是php 二维数组排序的代码
function arraySort($arr, $keys, $type = 'asc') {
$keysvalue = $new_array = array();
foreach ($arr as $k => $v){
$keysvalue[$k] = $v[$keys];
}
$type == 'asc' ? asort($keysvalue) : arsort($keysvalue);
reset($keysvalue);
foreach ($keysvalue as $k => $v) {
$new_array[$k] = $arr[$k];
}
return $new_array;
}
$arr[] = array("name"=>"1","time"=>1) ;
array_multisort(array1,sorting order, sorting type,array2,array3..)是对多个数组或多维数组进行排序的函数。
<?php
function my_sort($arrays,$sort_key,$sort_order=SORT_ASC,$sort_type=SORT_NUMERIC ){
if(is_array($arrays)){
foreach ($arrays as $array){
if(is_array($array)){
$key_arrays[] = $array[$sort_key];
}else{
return false;
}
}
}else{
return false;
}
array_multisort($key_arrays,$sort_order,$sort_type,$arrays);
return $arrays;
}
$person = array(
array('id'=>1,'name'=>'fj','weight'=>100,'height'=>180),
array('id'=>2,'name'=>'tom','weight'=>53,'height'=>150),
array('id'=>3,'name'=>'jerry','weight'=>120,'height'=>156),
array('id'=>4,'name'=>'bill','weight'=>110,'height'=>190),
array('id'=>5,'name'=>'linken','weight'=>80,'height'=>200),
array('id'=>6,'name'=>'madana','weight'=>95,'height'=>110),
array('id'=>7,'name'=>'jordan','weight'=>70,'height'=>170)
);
var_dump($person);
$person = my_sort($person,'name',SORT_ASC,SORT_STRING);
var_dump($person);
$person = my_sort($person,'weight');
var_dump($person);
?>
结果如下:
array (size=7)
0 =>
array (size=4)
'id' => int 1
'name' => string 'fj' (length=2)
'weight' => int 100
'height' => int 180
1 =>
array (size=4)
'id' => int 2
'name' => string 'tom' (length=3)
'weight' => int 53
'height' => int 150
2 =>
array (size=4)
'id' => int 3
'name' => string 'jerry' (length=5)
'weight' => int 120
'height' => int 156
3 =>
array (size=4)
'id' => int 4
'name' => string 'bill' (length=4)
'weight' => int 110
'height' => int 190
4 =>
array (size=4)
'id' => int 5
'name' => string 'linken' (length=6)
'weight' => int 80
'height' => int 200
5 =>
array (size=4)
'id' => int 6
'name' => string 'madana' (length=6)
'weight' => int 95
'height' => int 110
6 =>
array (size=4)
'id' => int 7
'name' => string 'jordan' (length=6)
'weight' => int 70
'height' => int 170
array (size=7)
0 =>
array (size=4)
'id' => int 4
'name' => string 'bill' (length=4)
'weight' => int 110
'height' => int 190
1 =>
array (size=4)
'id' => int 1
'name' => string 'fj' (length=2)
'weight' => int 100
'height' => int 180
2 =>
array (size=4)
'id' => int 3
'name' => string 'jerry' (length=5)
'weight' => int 120
'height' => int 156
3 =>
array (size=4)
'id' => int 7
'name' => string 'jordan' (length=6)
'weight' => int 70
'height' => int 170
4 =>
array (size=4)
'id' => int 5
'name' => string 'linken' (length=6)
'weight' => int 80
'height' => int 200
5 =>
array (size=4)
'id' => int 6
'name' => string 'madana' (length=6)
'weight' => int 95
'height' => int 110
6 =>
array (size=4)
'id' => int 2
'name' => string 'tom' (length=3)
'weight' => int 53
'height' => int 150
array (size=7)
0 =>
array (size=4)
'id' => int 2
'name' => string 'tom' (length=3)
'weight' => int 53
'height' => int 150
1 =>
array (size=4)
'id' => int 7
'name' => string 'jordan' (length=6)
'weight' => int 70
'height' => int 170
2 =>
array (size=4)
'id' => int 5
'name' => string 'linken' (length=6)
'weight' => int 80
'height' => int 200
3 =>
array (size=4)
'id' => int 6
'name' => string 'madana' (length=6)
'weight' => int 95
'height' => int 110
4 =>
array (size=4)
'id' => int 1
'name' => string 'fj' (length=2)
'weight' => int 100
'height' => int 180
5 =>
array (size=4)
'id' => int 4
'name' => string 'bill' (length=4)
'weight' => int 110
'height' => int 190
6 =>
array (size=4)
'id' => int 3
'name' => string 'jerry' (length=5)
'weight' => int 120
'height' => int 156
这里的重点就是,先把要排序的key存到一个一维数组中,然后就可以使用array_multisort()这个函数,将数组按照key进行排序了,当然,这里的排序你完全可以不适用array_multisort()这个函数,仅仅通过foreach遍历也能达到这个效果,但是既然php开发者给我们提供了更好的办法,我们就可以省去不必要的麻烦了
重复数组在工作中就和重复数据一样可能影响到统计了,这里我们来看在php中重复数组的一个处理操作步骤。
php本身有提供一些函数,有一个出去重复的函数就是array_unique,这个函数会去除相同的值,这样可以给我们开发者带来方便,去除重复的值后在获取数组的长度,和未去除重复的长度来比较,下面代码不只是否可以用在二维数组上,我用的是一维数组
php 判断是否有重复数组代码
if(count($pf_shuliang) != count(array_unique($pf_shuliang))) showErr("批发数量不可重复",$ajax);
二维数组根据键值排序
public function sort($arr,$sort,$v){ //$arr->数组 $sort->排序顺序标志 $value->排序字段
if($sort == "0"){ //排序顺序标志 SORT_DESC 降序;SORT_ASC 升序
$sort = "SORT_ASC";
}elseif ($sort == "1") {
$sort = "SORT_DESC";
}
foreach($arr as $uniqid => $row){
foreach($row as $key=>$value){
$arrsort[$key][$uniqid] = $value;
}
}
if($sort){
array_multisort($arrsort[$v], constant($sort), $arr);
}
return $arr;
}
方法三
<?php
$input = array(4, "4", "3", 4, 3, "3");
$result = array_unique($input);
var_dump($result);
?>
第一个单元将被保留
。
例子1. array_unique() 例子
<?php
$input = array("a" => "green", "red", "b" => "green", "blue", "red");
$result = array_unique($input);
print_r($result);?>上例将输出:
Array([a] => green[0] => red[1] => blue)例子2. array_unique() 和类型
上例将输出:
<?php
$input = array(4, "4", "3", 4, 3, "3");
$result = array_unique($input);
var_dump($result);?>
一,比较简单的实现文件上传
文件上传原理
文件上传原理:将客户端的文件先上传到服务器端,然后再将服务器端的临时文件移动到指定的目录。
客户端配置
要上传文件,我们需要采用表单,并且表单发送的形式来POST请求,而且要求将enctype设置为multipart/form-data,总结上传的条件如下:
浏览器表单页面
表单发送方式为post
指定enctype=multipart/form-data
客户端的代码:
<form action="uploadFile.php" method="post" accept-charset="utf-8" enctype="multipart/form-data">
请选择要上传的文件:
<input type="file" name="myfile">
<input type="submit" value="上传文件">
</form>
$_FILES文件变量
下面是上传一个图片然后打印整理出来的数据:
// name => 'QC8054R7QPGQ_1000x500.jpg'
// type => 'image/jpeg'
// tmp_name => '/Applications/MAMP/tmp/php/php1X5KZU'
// error => 0
// size => 229936
$_FILES上传的参数含义说明:
name:上传的文件的名称
type: 上传的文件的MIME类型
tmp_name:文件上传到服务器的临时路径
site:上传的文件的大小
error:上传的文件的错误码,0表示上传成功UPLOAD_ERR_OK
移动文件
移动文件方式一
上传文件到服务器端是在一个临时路径下,我们需要将文件移动到指定的目录下,我们可以通过下面的函数来实现移动:
// 将指定的文件移到的目录路径下
// 要求待移动的文件是通过HTTP POST上传的
bool move_uploaded_file ( string $filename , string $destination )
我们需要判断一下是否是通过HTTP POST上传的,下面的方法可以判断:
// 判断文件是否是通过HTTP POST上传的,如果是返回TRUE,否则返回FALSE
bool is_uploaded_file ( string $filename )
移动文件方式二
我们还可以通过下面的函数来实现移动文件:
// 参数一:待移动的文件
// 参数二:移动到的目标路径
bool copy ( string $source , string $dest [, resource $context ] )
处理上传
<?php
define('UPLOAD_PATH', 'Uploads');
$name = $_FILES['myfile']['name'];
$type = $_FILES['myfile']['type'];
$tmp_name = $_FILES['myfile']['tmp_name'];
$error = $_FILES['myfile']['error'];
$size = $_FILES['myfile']['size'];
if ($error == UPLOAD_ERR_OK) {
if (is_uploaded_file($tmp_name)) {
move_uploaded_file($tmp_name, UPLOAD_PATH . '/' . $name);
} else {
if (is_file($tmp_name) && !copy($tmp_name, UPLOAD_PATH . '/' . $name)) {
var_dump('ok');
}
}
} else {
// 上传到服务器就已经出错了
var_dump($error);
}
php.ini上传配置
假设我们要支持上传20M的文件,那么我们可以设置以下选项:
// 一定要设置为On,才能上传文件,若设置为Off,则服务器是接收不到文件数据的
file_uploads = On
// 指定上传文件到服务器的临时目录,默认为不打开的,可以不写
upload_tmp_dir = "d:/uploads_tmp"
// 支持上传的文件的最大为20M
upload_max_filesize = 20M
// 设置POST请求允许一次请求的最大值为100M
post_max_size = 100M
// 上传操作允许的最长时间,超过600秒则会停止脚本运行,0表示无限制
max_execution_time = 600
// PHP脚本解析请求数据所用的最大时间,默认为60秒,0表示无限制
max_input_time = 600
// 单个PHP脚本所能申请的最大内存,-1表示无限制!
memory_limit = 128M
上传文件错误码
UPLOAD_ERR_OK:代表上传成功
UPLOAD_ERR_EXTENSION:上传的文件被PHP扩展程序中断
UPLOAD_ERR_PARTIAL:文件只有部分被上传
UPLOAD_ERR_CANT_WRITE:文件写入失败
UPLOAD_ERR_FORM_SIZE:表单文件超过了post_max_size
UPLOAD_ERR_INI_SIZE:文件大小超过了限制上传的大小
UPLOAD_ERR_NO_FILE:没有文件被上传
UPLOAD_ERR_NO_TMP_DIR:找不到临时目录
客户端限制上传
我们可以通过隐藏域来实现限制上传的文件大小,同时可以通过accept来限制上传的文件的类型,如下所示:
<form action="uploadFile.php" method="post" accept-charset="utf-8" enctype="multipart/form-data">
<input type="hidden" name="MAX_FILE_SIZE" value="1024">
请选择要上传的文件:
<input type="file" name="myfile" accept="image/png">
<input type="submit" value="上传文件">
</form>
服务端限制上传
我们可以通过在服务端来判断文件类型、文件大小,上传方式等来判断是否满足条件,然后才处理文件!
<?php
define('UPLOAD_PATH', 'Uploads');
define('MAX_FILE_SIZE', 2 * 1024 * 1024);
header('Content-type:text/html;Charset=utf-8');
$name = $_FILES['myfile']['name'];
$type = $_FILES['myfile']['type'];
$tmp_name = $_FILES['myfile']['tmp_name'];
$error = $_FILES['myfile']['error'];
$size = $_FILES['myfile']['size'];
$allowExt = array('png', 'jpg', 'jpeg');
if ($error == UPLOAD_ERR_OK) {
if ($size > MAX_FILE_SIZE) {
exit('上传的文件过大');
}
// 取上传的文件的扩展类型
$ext = pathinfo($name, PATHINFO_EXTENSION);
if (!in_array($ext, $allowExt)) {
exit('非法文件类型');
}
if (!is_uploaded_file($tmp_name)) {
exit('文件不是HTTP POST上传过来的');
}
if (move_uploaded_file($tmp_name, UPLOAD_PATH . '/' . $name)) {
echo '文件上传成功';
} else {
echo "文件上传失败";
}
} else {
// 上传到服务器就已经出错了
var_dump($error);
}
忽略文件重名之类的问题,那些需要额外添加一些小处理哦!
二,上传文件类
<?php
ini_set('display_errors', 'On');
error_reporting(E_ALL);
header('Content-type:text/html;Charset=utf-8');
/**
* Class for Uploading a single image
*/
class Upload {
protected $fileName; /* eg, $_FILES['file'], the name is file. */
protected $allowExt; /* Allow extension for uploading a file */
protected $allowMIMEType; /* Allow uploading file mine types */
protected $fileMaxSize; /* Limit a uploading file size */
protected $uploadPath; /* The destination path */
protected $isImageFlag; /* Note that file is an image or not. */
protected $errorMessage;
protected $fileExt;
protected $fileInfos;
protected $fileUniqueName;
protected $fileDestPath;
public function __construct($fileName = 'file', $uploadPath = './Uploads', $isImageFlag = true, $fileMaxSize = 1048576, $allowExt = array('png', 'jpg', 'jpeg', 'gif'), $allowMIMEType = array('image/png', 'image/jpeg', 'image/gif')) {
$this->fileName = $fileName;
$this->allowExt = $allowExt;
$this->allowMIMEType = $allowMIMEType;
$this->uploadPath = $uploadPath;
$this->isImageFlag = $isImageFlag;
$this->fileMaxSize = $fileMaxSize;
// print_r($_FILES);
$this->fileInfos = $_FILES[$fileName];
}
public function uploadFile() {
if ($this->isValidExt()
&& $this->isValidMIMEType()
&& $this->isValidFileSize()
&& $this->isRealImage()
&& $this->isHTTPPOST()
&& !$this->hasError()) {
$this->isUploadPathExist();
$this->fileUniqueName = $this->getUniqueName();
$this->fileDestPath = $this->uploadPath . '/' . $this->fileUniqueName . '.' . $this->fileExt;
// echo iconv('gb2312', 'UTF-8', $this->fileDestPath);
if (@move_uploaded_file($this->fileInfos['tmp_name'], $this->fileDestPath)) {
return $this->fileDestPath;
} else {
$this->errorMessage = '文件上传失败';
}
} else {
$this->errorMessage = '文件上传失败';
}
exit('<span style="color:red">'.$this->errorMessage.'</span>');
}
protected function hasError() {
$ret = true;
if (!is_null($this->fileInfos)) {
switch ($this->fileInfos['error']) {
case UPLOAD_ERR_INI_SIZE:
$this->errorMessage = '文件大小超过PHP.ini文件中upload_max_filesize';
break;
case UPLOAD_ERR_FORM_SIZE:
$this->errorMessage = '文件大小超过了表单中MAX_FILE_SIZE设置的值';
break;
case UPLOAD_ERR_NO_TMP_DIR:
$this->errorMessage = '找不到临时文件目录';
break;
case UPLOAD_ERR_NO_FILE:
$this->errorMessage = '没有选择任何文件上传';
break;
case UPLOAD_ERR_CANT_WRITE:
$this->errorMessage = '文件不可写';
break;
case UPLOAD_ERR_PARTIAL:
$this->errorMessage = '只有部分文件被上传';
break;
case UPLOAD_ERR_EXTENSION:
$this->errorMessage = '文件上传过程中被PHP扩展程序中断';
break;
default:
$this->errorMessage = '';
$ret = false;
}
} else {
$this->errorMessage = '文件上传出错';
}
return $ret;
}
protected function isValidFileSize() {
if ($this->fileInfos['size'] > $this->fileMaxSize) {
$this->errorMessage = '文件太大';
return false;
}
return true;
}
protected function isValidExt() {
$ext = pathinfo($this->fileInfos['name'], PATHINFO_EXTENSION);
if (!in_array($ext, $this->allowExt)) {
$this->errorMessage = '不支持的文件类型';
return false;
}
$this->fileExt = $ext;
return true;;
}
protected function isValidMIMEType() {
$type = $this->fileInfos['type'];
if (!in_array($type, $this->allowMIMEType)) {
$this->errorMessage = '不支持的文件MIME类型';
return false;
}
return true;
}
protected function isHTTPPOST() {
if (!is_uploaded_file($this->fileInfos['tmp_name'])) {
$this->errorMessage = '文件不是通过HTTP POST传上来的';
return false;
}
return true;
}
protected function isRealImage() {
if ($this->isImageFlag && !getimagesize($this->fileInfos['tmp_name'])) {
$this->errorMessage = '文件不是图片';
return false;
}
return true;
}
protected function isUploadPathExist() {
if (!file_exists($this->uploadPath)) {
mkdir($this->uploadPath, 0777, true);
}
}
protected function getUniqueName() {
return md5(microtime(true), true);
}
}
$upload = new Upload('myfile');
if ($upload->uploadFile()) {
echo "文件上传成功";
}
最近在看PHP内部实现的东西,想要了解PHP是如何从一个.php文件经过词法/语法/语义等分析生成OPCODE的。
鸟哥在博客里面安利了vld.so这个php opcode dump工具,网上没有在osx下mamp安装opcode的教程,自己鼓捣了一下,记录一下方便后人。
前提需要安装xcode command line tool这个网上教程比较多,自己去搜一下吧。
首先在/Applications/MAMP/bin/php中新建一个目录include。
下载一个对应版本的php源码解压到这个目录,并且
./configure
make && make install
之后导入shell环境变量到当前目录
echo "export PATH=/Applications/MAMP/bin/php/php{对应版本}/bin:$PATH" >> ~/.profile
运行
. ~/.profile
pear config-set php_ini /Applications/MAMP/bin/php/php{对应版本}/conf/php.ini
pecl config-set php_ini /Applications/MAMP/bin/php/php{对应版本}/conf/php.ini
更新pecl
pecl channel-update pecl.php.net
下载与安装VLD
wget http://pecl.php.net/get/vld-{对应版本}.tgz
tar zxvf vld-{对应版本}.tgz
cd ./vld-{对应版本}
/Applications/MAMP/bin/php/php{对应版本}/bin/phpize
./configure --with-php-config=/Applications/MAMP/bin/php/php{对应版本}/bin --enable-vld
make && make install
然后在
/Applications/MAMP/bin/php/php{对应版本}/conf/php.ini中添加
[vld]
extension=vld.so
并且在mamp的选项edit template里修改php.ini
然后source ~/.profile
之后php运行
php -dvld.active=1 /path/to/your/code.php
就可以看到opcode的输出了
冒泡排序我们排序算法中的许多中的其中一样了,这里我们一起来了解一下php实现冒泡排序实现方法与原理,具体如下。
一个程序应包括:
对数据的描述:在程序中要指定数据的类型和数据的组织形式,即数据结构(data structure)。
对操作的描述:即操作步骤,也就是算法(algorithm)。
Nikiklaus Wirth提出的公式:程序=数据结构+算法
作为一个?潘砍绦蛟北匦氲枚?闼惴ò?就从最简单的开始吧=> 冒泡排序
维基百科的说法
冒泡排序(英语:Bubble Sort,台湾另外一种译名为:泡沫排序)是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。
我理解冒泡排序就是小学生排队,你比我个子矮(数字小),你就站我前面(浮上去),直到找到比我个子高那个,我站在他的前面,他继续往后面比个子!
直接上PHP代码
<?php
$arr = array(1, 43, 54, 72, 21, 66, 32,55,11, 78, 36, 76, 39,88);
function getpao($arr)
{
$len = count($arr);
//设置一个空数组 用来接收冒出来的泡
//该层循环控制 需要冒泡的轮数
for ($i = 1; $i < $len; $i++) { //该层循环用来控制每轮 冒出一个数 需要比较的次数
for ($k = 0; $k < $len - $i; $k++) {
if ($arr[$k] > $arr[$k + 1]) {
$tmp = $arr[$k + 1];
$arr[$k + 1] = $arr[$k];
$arr[$k] = $tmp;
}
}
}
return $arr;
}
var_dump(getpao($arr));
运行结果
相关文章
- 在php中eval是一个函数并且不能直接禁用了,但eval函数又相当的危险了经常会出现一些问题了,今天我们就一起来看看eval函数对数组的操作 例子, <?php $data="array...2016-11-25
- 这篇文章主要介绍了Python 图片转数组,二进制互转操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-03-09
- 本文章提供在量的数据中级操作实例有如对键名比较计算数组的差集 计算差集 给指定数组中插入一个元素 反转数组 交集赋值新的数组实例。 //定义回调函数 funct...2016-11-25
- 这篇文章主要介绍了C#二维数组基本用法,以实例形式分析了C#中二维数组的定义、初始化、遍历及打印等用法,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
- Array数组在C#中同样是最基本的数据结构,下面为大家C#数组的常用操作方法小结,皆为细小的代码段,欢迎收看收藏...2020-06-25
- 下面一段代码给大家介绍php curl模拟post请求的示例代码,具体代码如下: <?php$uri = "http://www.cnblogs.com/test.php";//这里换成自己的服务器的地址// 参数数组$data = array ( 'name' => 'tanteng'// 'passwor...2015-11-24
- 下面小编就为大家带来一篇C# 拷贝数组的几种方法(总结)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-06-25
- 本文记录的要实现的功能类似于 MySQL 中的 ORDER BY,上个项目中有遇到这样的一个需求。 要求:从两个不同的表中获取各自的4条数据,然后整合(array_merge)成一个数组,再根据数据的创建时间降序排序取前4条。 遇到这个...2014-06-07
- 这篇文章主要介绍了C#实现字符串转换成字节数组的简单实现方法,仅一行代码即可搞定,非常简单实用,需要的朋友可以参考下...2020-06-25
- 这篇文章主要介绍了c#将字节数组转成易读的字符串的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-06-25
- 这篇文章主要介绍了C#读取文件所有行到数组的方法,涉及C#针对文件及数组的相关操作技巧,需要的朋友可以参考下...2020-06-25
- 如何将下面的二维数组转为一维数组。复制代码 代码如下:$msg = array( array( 'id'=>'45', 'name'=>'jack' ), array( 'id'=>'34', 'name'=>'mary' ), array( 'id...2014-05-31
- 在php中为我们提供了一个函数var_export 他可以直接将php代码入到一个文件中哦。 代码如下 复制代码 var_export($times,true);后面不加tru...2016-11-25
- 本文为代码分享,也是在工作中看到一些“大牛”的代码,做做分享。 具体是这样的,如下一个二维数组,是从库中读取出来的。 代码清单: 复制代码 代码如下: $user = array( 0 => array( 'id' => 1, 'name' => '张三', 'ema...2014-06-07
- 1.前言 昨天碰到一道关于如何解决有序数组的连接问题,这是一个很常见的问题。但是这里要考虑到代码的效率问题,因为要连接的数组都是有序的,这是一个非常重要的前提条件。2.简单但效率不高的算法 我首先想到的是使用...2013-10-04
- 今天小编就为大家分享一篇python 实现将Numpy数组保存为图像,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-04-27
C#中数组、ArrayList、List、Dictionary的用法与区别浅析(存取数据)
在工作中经常遇到C#数组、ArrayList、List、Dictionary存取数据,但是该选择哪种类型进行存储数据呢?很迷茫,今天小编抽空给大家整理下这方面的内容,需要的朋友参考下吧...2020-06-25- 这篇文章主要介绍了C#中List和数组之间转换的方法,涉及比较简单的转换技巧,需要的朋友可以参考下...2020-06-25
- 下面小编就为大家带来一篇javascript中去除数组重复元素的实现方法【实例】。小编觉得挺不错的,现在分享给大家,也给大家做个参考,一起跟随小编过来看看吧...2016-04-16
- 下面小编就为大家带来一篇Perl与JS的对比分析(数组、哈希)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-06-29