同事处理数据时遇到一个问题:客户要求的文件格式是第一行是统计数据,后面换行后紧跟的是明细记录。
要保证明细记录的数量与统计数据一致就必须在写完明细之后再写入统计数据,而且数据的量在百万级,所以不太可能先读到内存再汇总后一起写入。
最后找到的解决办法如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
$offset
= 50;
$fp
=
fopen
(
"fseek.txt"
,
"wb"
);
// 创建文件
flock
(
$fp
, LOCK_EX);
// 锁定
fwrite(
$fp
,
"\n"
);
// 写入一空行
fseek
(
$fp
,
$offset
);
// 移动文件指针至偏移量处,相当于空出了50个字节的内存空间
// 写数据,汇总
$write_count
= 0;
for
(
$i
= 0;
$i
< 10;
$i
++)
{
fwrite(
$fp
,
"abc\n"
);
$write_count
++;
}
fseek
(
$fp
, 0);
// 文件指针再移到文件头
// 写入汇总记录,并用空格填充余下的内存空间
fwrite(
$fp
,
str_pad
(
"total count:"
.
$write_count
,
$offset
- 1,
" "
, STR_PAD_RIGHT).
"\n"
);
flock
(
$fp
, LOCK_UN);
// 解锁
fclose(
$fp
);
// 关闭文件
|
本文转自 ustb80 51CTO博客,原文链接:http://blog.51cto.com/ustb80/1285471,如需转载请自行联系原作者