我正在尝试创建一个制表符分隔的文件输出,我可以使用它来加载到 quickbooks 中。我在 header 上使用以下代码。
header("Content-type: text/plain");
header("Content-Disposition: attachment; filename=\"my-data.txt\"");
我有两个问题。
首先是一些内容是文本,但其中有一个逗号 ,(这就是我使用制表符分隔的原因。SQL(友善地)为我在这些字段周围放置了“”,然后将其传输到文本文件,然后再传输到帐户包中。我看不出如何阻止 SQL 这样做或如何将其从文本文件的内容中删除。
其次,脚本中的第一个输出是一个回显语句,后跟一个制表符等;然而,实际输出在开头包含一个额外的行(我可以看到插入了一个 ASCII 0A)我看不出这是从哪里来的?
我附上了我正在使用的代码,以防我遗漏一些明显的东西。
帮助
非常感谢
<?php
header("Content-type: text/plain");
header("Content-Disposition: attachment; filename=\"my-data.txt\"");
// Open standard includes
include ('./includes/protect.php'); //User name and password control
require_once('Connections/Dragonnet.php');
mysql_select_db($database_Dragonnet, $Dragonnet); //Connect to database
?>
<?php
$batch1 = $_GET["batch1"];
$batch2 = $_GET["batch2"];
$query = "SELECT invtrans.StdInvNar1 AS 'invtrans StdInvNar1',
invtrans.StdInvNar2 AS 'invtrans StdInvNar2',
invtrans.StdInvNar3 AS 'invtrans StdInvNar3',
invtrans.StdInvNar4 AS 'invtrans StdInvNar4',
invtrans.StdInvNar5 AS 'invtrans StdInvNar5',
invtrans.StdInvNar6 AS 'invtrans StdInvNar6',
invtrans.StdInvNar7 AS 'invtrans StdInvNar7',
invtrans.StdInvNar8 AS 'invtrans StdInvNar8',
invtrans.StdInvNar9 AS 'invtrans StdInvNar9',
invtrans.StdInvNar10 AS 'invtrans StdInvNar10',
invtrans.InvNar1 AS 'invtrans InvNar1',
invtrans.InvNar2 AS 'invtrans InvNar2',
invtrans.InvNar3 AS 'invtrans InvNar3',
invtrans.InvNar4 AS 'invtrans InvNar4',
invtrans.InvNar5 AS 'invtrans InvNar5',
invtrans.InvNar6 AS 'invtrans InvNar6',
invtrans.InvNar7 AS 'invtrans InvNar7',
invtrans.InvNar8 AS 'invtrans InvNar8',
invtrans.InvNar9 AS 'invtrans InvNar9',
invtrans.InvNar10 AS 'invtrans InvNar10',
invtrans.Charge AS 'invtrans Charge',
invtrans.Cost AS 'invtrans Cost',
invtrans.VATtype AS 'invtrans VATtype',
invtrans.VATRate AS 'invtrans VATRate',
invtrans.SiteName AS 'invtrans SiteName',
invtrans.SiteTown AS 'invtrans SiteTown',
invtrans.UnitPrice AS 'invtrans UnitPrice',
invtrans.Type AS 'invtrans Type',
invtrans.InvBatch AS 'invtrans InvBatch',
invoiceheaders.Name AS 'invoiceheaders Name',
invoiceheaders.Addr1 AS 'invoiceheaders Addr1',
invoiceheaders.Addr2 AS 'invoiceheaders Addr2',
invoiceheaders.Addr3 AS 'invoiceheaders Addr3',
invoiceheaders.Town AS 'invoiceheaders Town',
invoiceheaders.County AS 'invoiceheaders County',
invoiceheaders.Country AS 'invoiceheaders Country',
invoiceheaders.PostCode AS 'invoiceheaders PostCode',
invoiceheaders.EMail AS 'invoiceheaders EMail',
invoiceheaders.Fax AS 'invoiceheaders Fax',
invoiceheaders.InvNo AS 'invoiceheaders InvNo',
invoiceheaders.InvDate AS 'invoiceheaders InvDate',
invoiceheaders.InvType AS 'invoiceheaders InvType',
invoiceheaders.DelType AS 'invoiceheaders DelType'
FROM (invtrans invtrans
INNER JOIN invoiceheaders invoiceheaders ON (invoiceheaders.InvNo = invtrans.InvNumber ))
WHERE
(
invtrans.InvBatch = "."'".$batch1."'"." OR invtrans.InvBatch = "."'".$batch2."'"." )
ORDER BY invoiceheaders.InvNo
";
$result = mysql_query($query) or die(mysql_error());
//Create Headers
echo "Customer Ref";
echo chr(9);
echo "Account Ref";
echo chr(9);
echo "TxnDate";
echo chr(9);
echo "Invoice No";
echo chr(9);
echo "BillingAddress1";
echo chr(9);
echo "BillingAddress2";
echo chr(9);
echo "BillingAddress3";
echo chr(9);
echo "BillingAddressTown";
echo chr(9);
echo "BillingAddressCounty";
echo chr(9);
echo "BillingAddressCountry";
echo chr(9);
echo "BillingAddressPostcode";
echo chr(9);
echo "Phone";
echo chr(9);
echo "Fax";
echo chr(9);
echo "email";
echo chr(9);
echo "Description";
echo chr(9);
echo "Rate";
echo chr(9);
echo "UnitOfMeasure";
echo chr(9);
echo "SalesTaxCode";
echo chr(9);
echo "Amount";
echo chr(9);
echo chr(13);
while($row = mysql_fetch_array($result))
{
//create variables
$description = $row['invtrans StdInvNar1']." ".$row['invtrans StdInvNar2']." ".$row['invtrans StdInvNar3']." ".$row['invtrans StdInvNar4']." ".$row['invtrans StdInvNar5']." ".$row['invtrans StdInvNar6']." ".$row['invtrans StdInvNar7']." ".$row['invtrans StdInvNar8']." ".$row['invtrans StdInvNar9']." ".$row['invtrans StdInvNar10'];
$description = $description." ".$row['invtrans InvNar1']." ".$row['invtrans InvNar2']." ".$row['invtrans InvNar3']." ".$row['invtrans InvNar4']." ".$row['invtrans InvNar5']." ".$row['invtrans InvNar6']." ".$row['invtrans InvNar7']." ".$row['invtrans InvNar8']." ".$row['invtrans InvNar9']." ".$row['invtrans InvNar10'];
//output file
echo $row['invoiceheaders Name'];
echo chr(9);
echo "Account Ref";
echo chr(9);
echo $row['invoiceheaders InvDate'];
echo chr(9);
echo $row['invoiceheaders InvNo'];
echo chr(9);
echo $row['invoiceheaders Addr1'];
echo chr(9);
echo $row['invoiceheaders Addr2'];
echo chr(9);
echo $row['invoiceheaders Addr3'];
echo chr(9);
echo $row['invoiceheaders Town'];
echo chr(9);
echo $row['invoiceheaders County'];
echo chr(9);
echo $row['invoiceheaders Country'];
echo chr(9);
echo $row['invoiceheaders PostCode'];
echo chr(9);
echo "01212331234";
echo chr(9);
echo $row['invoiceheaders Fax'];
echo chr(9);
echo $row['invoiceheaders EMail'];
echo chr(9);
echo $description;
echo chr(9);
echo $row['invtrans Charge'];
echo chr(9);
echo "UnitOfMeasure";
echo chr(9);
echo "SalesTaxCode";
echo chr(9);
echo $row['invtrans Charge'];
echo chr(9);
echo chr(13);
}
?>
最佳答案
使用内置的 fputcsv()使用“\t”分隔符而不是尝试“滚动你自己的”
关于php - 创建制表符分隔文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8995339/
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
出于纯粹的兴趣,我很好奇如何按顺序创建PI,而不是在过程结果之后生成数字,而是让数字在过程本身生成时显示。如果是这种情况,那么数字可以自行产生,我可以对以前看到的数字实现垃圾收集,从而创建一个无限系列。结果只是在Pi系列之后每秒生成一个数字。这是我通过互联网筛选的结果:这是流行的计算机友好算法,类机器算法:defarccot(x,unity)xpow=unity/xn=1sign=1sum=0loopdoterm=xpow/nbreakifterm==0sum+=sign*(xpow/n)xpow/=x*xn+=2sign=-signendsumenddefcalc_pi(digits
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我对最新版本的Rails有疑问。我创建了一个新应用程序(railsnewMyProject),但我没有脚本/生成,只有脚本/rails,当我输入ruby./script/railsgeneratepluginmy_plugin"Couldnotfindgeneratorplugin.".你知道如何生成插件模板吗?没有这个命令可以创建插件吗?PS:我正在使用Rails3.2.1和ruby1.8.7[universal-darwin11.0] 最佳答案 随着Rails3.2.0的发布,插件生成器已经被移除。查看变更日志here.现在