我想验证表格中的数字字段(价格)
我试着以这种方式验证10.00
这样的格式,没关系。
$pattern = '/^\d+(:?[.]\d{2})$/';
if (preg_match($pattern, $_POST['price']) == '0') {
echo "ERROR";
exit;
}
现在,我想验证同时,10.00
和10
等字段格式。
我怎么能这样做?
答案 0 :(得分:11)
你的新模式:
$pattern = '/^\d+(\.\d{2})?$/';
将验证:
10
10.00
如果你想无效零前导数字,例如05.00,以下模式将有所帮助:
$pattern = '/^(0|[1-9]\d*)(\.\d{2})?$/';
答案 1 :(得分:2)
如果你只检查它是否是一个数字,is_numeric()在这里要好得多。它比正则表达式更具可读性和快速性。
答案 2 :(得分:-1)
我迅速启动了一个函数,用于检查字符串或整数是否是有效价格,如果不是,则将其转换。最终输出将始终是小数点后两位的字符串,例如1000.00
。
它删除负号/负号,逗号,空格和美元符号。唯一的例外是,如果字符串包含字母之类的任何字符,这些字符会将is_numeric()
设置为false。
功能如下:
function convertToValidPrice($price) {
$price = str_replace(['-', ',', '$', ' '], '', $price);
if(!is_numeric($price)) {
$price = null;
} else {
if(strpos($price, '.') !== false) {
$dollarExplode = explode('.', $price);
$dollar = $dollarExplode[0];
$cents = $dollarExplode[1];
if(strlen($cents) === 0) {
$cents = '00';
} elseif(strlen($cents) === 1) {
$cents = $cents.'0';
} elseif(strlen($cents) > 2) {
$cents = substr($cents, 0, 2);
}
$price = $dollar.'.'.$cents;
} else {
$cents = '00';
$price = $price.'.'.$cents;
}
}
return $price;
}
这里是测试它:
var_dump(convertToValidPrice('100')); // 100.00
var_dump(convertToValidPrice('-100')); // 100.00
var_dump(convertToValidPrice(100)); // 100.00
var_dump(convertToValidPrice('$100')); // 100.00
var_dump(convertToValidPrice('100.98')); // 100.98
var_dump(convertToValidPrice('100.9')); // 100.90
var_dump(convertToValidPrice('100.')); // 100.00
var_dump(convertToValidPrice('1,00.98')); // 100.98
var_dump(convertToValidPrice('1,000.98')); // 1000.98
var_dump(convertToValidPrice('100.98829382')); // 100.98
var_dump(convertToValidPrice('abc')); // null