preg_replace_callback 问题
程序员文章站
2022-03-14 10:56:18
...
$zheng="1";//重复的整合一起($wupin_rs或$wupin_add)$jia="0";//相加($wupin_rs,$wupin_add)$jian="0";//相减($wupin_rs,$wupin_add)$shanchu="0";//把数量为0的删除($wupin_rs)$suan="0";//算总价($wupin_rs)$wupin_rs="";//原有的$wupin_add="";//新添加/删除的//A类别0::::::品名1::::::品牌厂商2::::::规格3::::::单价4::::::单位5::::::数量6::::::总价7::::::重量8$wupin_rs="A类别0::::::品名1::::::品牌厂商2::::::规格3::::::1::::::单位5::::::10::::::0::::::100||||||A类别0::::::品名1::::::品牌厂商2::::::规格3::::::1::::::单位5::::::20::::::0::::::200||||||A类别0::::::品名1::::::品牌厂商2::::::规格3::::::1::::::单位5::::::30::::::0::::::200";if($wupin_rs&&$zheng==1){ $category=""; $morefr=explode('||||||',$wupin_rs); $mfcount=count($morefr); for($mfi=0;$mfi-1&&wupin_run_check($so)===false)//物品“类别”不显示重复类别(每种只显示一次),判断是否含有 { //改数量 $category= preg_replace_callback("/(?
弄了一上午,都弄不了,急求助
现在功能是当物品参数相同时,就自动相加数量,删除重复内容.
要求:除了以上功能外,还能相加重量,
要求输出:A类别0::::::品名1::::::品牌厂商2::::::规格3::::::1::::::单位5::::::60::::::0::::::500
回复讨论(解决方案)
$wupin_rs="A类别0::::::品名1::::::品牌厂商2::::::规格3::::::1::::::单位5::::::10::::::0::::::100||||||A类别0::::::品名1::::::品牌厂商2::::::规格3::::::1::::::单位5::::::20::::::0::::::200||||||A类别0::::::品名1::::::品牌厂商2::::::规格3::::::1::::::单位5::::::30::::::0::::::200";$pattern = '/(?=^|\|)\|*([^:]+)::::::([^:]+)::::::([^|:]+)::::::([^:]+)::::::([^:]+)::::::([^:]+)::::::([^:]+)::::::([^:]+)::::::([^|]+)/';$res = array();preg_replace_callback($pattern, function($m) use (&$res) { $k = join('::::::', array_slice($m, 1, 6)); $res[$k]['标识'] = $k; @$res[$k]['数量'] += $m[7]; @$res[$k]['总价'] += $m[5] * $m[7]; @$res[$k]['重量'] += $m[9]; }, $wupin_rs);echo join('||||||', array_map(function($t) { return join('::::::', $t); }, $res));A类别0::::::品名1::::::品牌厂商2::::::规格3::::::1::::::单位5::::::60::::::60::::::500
使用 preg_replace_callback 的目的在于减少 for 的层次,并不是他原有的功能:选择性替换
本例中就没有使用循环
推荐阅读
-
PHP中Notice: Undefined index: sku in 有关问题解决方案
-
网站刷新十秒钟就502了是什么问题,服务器配置很高
-
apache下PHP无法打开其他socket (permission denied)问题解决
-
控制文本是否能被替换的有关问题,求
-
一串加密字符串的解密有关问题
-
zend_form 装饰器有关问题
-
Bigcommerce:config.php的配置有关问题:无法写入自定义的新的配置信息
-
MySQL字符编码问题,Incorrect string value
-
sql server 2000下载 php Sql Server连接失败问题及解决办法
-
详解mysqldump数据导出的问题