我目前有一个文本文件,如下所示:
Test1 = 120827 = December 23, 2012:
Test2 = 147203 = December 23, 2012:
Test3 = 11806 = December 23, 2012:
Test4 = 11806 = December 23, 2012:
Test5 = 0 = December 23, 2012:
我想要做的是将第二列中的所有数字全部加在一起。我怎么能用PHP做到这一点?我的实际文件比这个文件大得多。
Test1 = *120827 = December 23, 2012:
Test2 = *147203 = December 23, 2012:
Test3 = *11806 = December 23, 2012:
Test4 = *11806 = December 23, 2012:
Test5 = *0 = December 23, 2012:
*我想添加的内容。
任何帮助都将受到高度赞赏!谢谢!
答案 0 :(得分:1)
PHP:
$sum = 0;
foreach (file($filename) as $line) {
list(,,$num) = explode(' ', $line);
$sum += $num;
}
如果文件太大,请使用fopen
+ fgets
代替file
。
BASH:
cut -d' ' -f3 filename | paste -sd+ | bc
答案 1 :(得分:0)
<?php
$pattern = '/(?<=\=\s)([0-9]+)(?=\s\=)/';
$total = 0;
$matches;
$filename = "add.txt";
$handle = @fopen($filename, "r");
if ($handle) {
while (($buffer = fgets($handle, 4096)) !== false) {
if(preg_match($pattern, $buffer, $matches))
{
$total += intval($matches[0]);
}
}
if (!feof($handle)) {
echo "Error: unexpected fgets() fail\n";
}
fclose($handle);
}
?>