詳解php中Null 字元串和0之間的關係

來源:互聯網
上載者:User

標籤:正則   global   函數   empty   match   保留   exec   row   get   

$_x=$row["x"];
$_y=$row["y"];
if(isset($_x) && isset($_y)){
if($row["y"] == 0 || $row["x"] == 0){
$d=$this->getDistance($row["y"],$row["x"],$y,$x);
}elseif(!empty($row["y"]) && !empty($row["x"])){
$d=$this->getDistance($row["y"],$row["x"],$y,$x);
}else{
continue;
}
if($d < $radius){
$list[]= $data[$key];
}
}

其實我是想要 過濾掉 經緯度為空白的資料,保留經度或緯度為0的資料,但發現在列印列表資料時,總是包含 經緯度為空白的資料。

研究了好久,才發現經緯度欄位是字元類型,當欄位為空白時進行  $row[‘y‘]== 0 判斷時?php進行自動轉換,所以$row[‘y‘]== 0判斷在Null 字元的情況下是正確的。於是總是包含經緯度為空白的資料。那麼怎麼去掉經緯度為空白的資料呢?
其實很簡單如下:

if(isset($_x) && isset($_y)){
if($row["y"] == "0" || $row["x"] == "0"){
$d=$this->getDistance($row["y"],$row["x"],$y,$x);

立即過濾掉經緯度為空白的資料。

下面是對preg_replace_callback進行代碼講解

$str="sdjfksdf2345";
$str=preg_replace_callback ( ‘/\d{4}/‘, function ($match){
return $match[0]."ff";
}, $str );
echo $str;
exit;

代碼運行結果為

sdjfksdf2345ff

該函數就是將正則匹配的結果作為匿名函數的參數,返回的結果作為替換的結果。

max_execution_time

預設是30秒.改為

max_execution_time = 0

0表示沒有限制

2. 修改 post_max_size

post_max_size 設定 POST 資料所允許的最大大小。此設定也影響到檔案上傳。
php預設的post_max_size 為2M.如果 POST 資料尺寸大於 post_max_size $_POST 和 $_FILES superglobals 便會為空白.
尋找 post_max_size改為

post_max_size = 150M

3. 修改upload_max_filesize

upload_max_filesize 表示所上傳的檔案的最大大小。

尋找upload_max_filesize,預設為8M改為

upload_max_filesize = 100M

另外要說明的是,post_max_size 大於 upload_max_filesize 為佳.

詳解php中Null 字元串和0之間的關係

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.