PHP 使用来自 MYSQL 问题的动态数据创建文本文件


PHP creating text file with dynamic data from MYSQL issue

我正在使用mysql db字段使用php编写文本文件,这些字段本质上是动态的。我无法保持列宽不变,请参阅下面的数据和列以更好地了解我的意思。

文本文件输出:

                450 65445 90900 87954          112
              90900 45875 24565 15484          KA01 23232

上述的 PHP 脚本:

$myFile = "testFile.txt";
$fh = fopen($myFile, 'w') or die("can't open file");
if ($quer2[DCNO1]>0){fwrite($fh, str_pad($quer2[DCNO1],19, " ", STR_PAD_LEFT));} if ($quer2[DCNO2]>0) {fwrite($fh, str_pad($quer2[DCNO2],6, " ", STR_PAD_LEFT));} if ($quer2[DCNO3]>0) {fwrite($fh, str_pad($quer2[DCNO3],6, " ", STR_PAD_LEFT));} if ($quer2[DCNO4]>0) {fwrite($fh, str_pad($quer2[DCNO4],6, " ", STR_PAD_LEFT));} 
fwrite($fh, str_pad($dchd2['PO_No'],13, " ", STR_PAD_LEFT));
$stringData = "'n";
fwrite($fh, $stringData);
if ($quer2[DCNO5]>0) {fwrite($fh, str_pad($quer2[DCNO5],19, " ", STR_PAD_LEFT));} if ($quer2[DCNO6]>0) {fwrite($fh, str_pad($quer2[DCNO6],6, " ", STR_PAD_LEFT));} if ($quer2[DCNO7]>0) {fwrite($fh, str_pad($quer2[DCNO7],6, " ", STR_PAD_LEFT));} if ($quer2[DCNO8]>0) {fwrite($fh, str_pad($quer2[DCNO8],6, " ", STR_PAD_LEFT));}
fwrite($fh, str_pad($dchd2['Vehicle_no'],20, " ", STR_PAD_LEFT));
$stringData = "'n";
fwrite($fh, $stringData);
fclose($fh);

现在,如果列中的一个值为 0,那么由于我的 IF 条件,空格将被删除,在这种情况下,我如何计算空间并给出这些额外的空间。

在我的 IF 条件下,如果其中一个值为 0,则输出文本文件:

                450 90900           112
              90900 45875 24565 15484          KA01 23232

使用制表位 ("''t")。它确保不同行上的每个项目都从相同的列开始。

这意味着当项目长度为 2 个字符且无法填充 4 个空格选项卡时,将添加 2 个空格。

请记住:不同的编辑器对制表符有不同的概念,有些通常插入空格而不是制表符。

编辑:实际上更简单的解决方案是有一个 else 子句并写成 str_pad(", 20);

你的代码非常繁忙,试着通过一个函数来集中它,你可以在一个地方处理"0"。 类似于以下内容(此代码尚未经过测试,但应该会给您正确的想法。

$myFile = "testFile.txt";
$fh = fopen($myFile, 'w') or die("can't open file");
function writepad($str,$pad)
{
    global $fh;
    if($str==0) $str=" "; //handle the case where str is 0, replace it with a space
    fwrite($fh,str_pad($str,$pad,STR_PAD_LEFT));
}
writepad($quer2[DCNO1],19);
writepad($quer2[DCNO2],6);
writepad($quer2[DCNO3],6);
writepad($quer2[DCNO4],6);
writepad($quer2['PO_No'],13); 
fwrite($fh, "'n");
writepad($quer2[DCNO5],19);
writepad($quer2[DCNO6],6);
writepad($quer2[DCNO7],6);
writepad($quer2[DCNO8],6);
writepad($quer2['Vehicle_no'],20); 
fwrite($fh, "'n");
fclose($fh);