Board logo

标题: 批处理命令可不可以直接用echo向xls文件写入数据? [打印本页]

作者: pykacha     时间: 2008-5-13 18:09    标题: 批处理命令可不可以直接用echo向xls文件写入数据?

问题描述:
我们可以用"echo %变量1% %变量2% >1.txt"命令向txt文件写入数据,为了方便数据的处理,我想直接把数据写入电子表格xls文件.
请问有没有办法做到?
作者: bat-zw     时间: 2008-5-13 18:19
I will tell you that bat have no idea
作者: slore     时间: 2008-5-13 18:24
I will tell you that vbs can do it.
作者: pykacha     时间: 2008-5-13 18:38


  Quote:
Originally posted by slore at 2008-5-13 06:24 PM:
I will tell you that vbs can do it.

关于VBS我也上网看过些文章,但还不会编写代码,前辈可不可以帮忙写个代码?
先谢谢!
作者: pooronce     时间: 2008-5-13 18:54
标准的xls有特殊格式,直接是不行的
不过你可以直接用echo配合数据及tab分割符来达到效果,文件名定义成xls就行了
作者: slore     时间: 2008-5-13 19:00
Set objExcel = CreateObject("Excel.Application")
objExcel.Visible = True
Set
objWb = objExcel.Workbooks.Add
Set objWs = objWb.Worksheets.Add
objExcel.Cells(1, 1).Value = "slore"

Set objExcel = Nothing
作者: pykacha     时间: 2008-5-14 16:28
slore前辈实现了真正意义的xls文件,可惜没自动保存。如果可以用bat文件把变量传递给它,调用它来保存为xls文件就好了。
pooronce前辈这种方法如果数据过多的时候再写入时会不会很慢?
作者: slore     时间: 2008-5-14 16:44
有自动保存,我只是为了让你看见=。=没有写……


Set objExcel = CreateObject("Excel.Application")
'objExcel.Visible = True           显示对象
'objExcel.DisplayAlerts = FALSE    覆盖方式保存
Set objWb = objExcel.Workbooks.Add
Set objWs = objWb.Worksheets.Add
objExcel.Cells(1, 1).Value = "Slore"
objWb.SaveAs("C:\Test.xls")
objExcel.Quit
Set objExcel = Nothing

参数当然有……自己可以查看VBS的Argument对象
或者找找例子
作者: pooronce     时间: 2008-5-14 17:11
汗……不要用那样的称呼,受不起
我说的相当于你直接写入到一个文本格式文件里,只是设定它的后辍为xls罢了,所以理论上说只会比标准xls快。

如果是大量数据需要处理的话,可以考虑学习使用gawk
作者: zh159     时间: 2008-5-14 17:39
还有另外一个方法:echo后缀为csv文件,数据采用“,”分号(英文分号)分割,可以直接用Excel打开,Excel处理后再存为xls文件

PS:简单测试发现支持部分公式:
csv
1,2,3,=A1+B1+C1
[ Last edited by zh159 on 2008-5-14 at 05:41 PM ]
作者: slore     时间: 2008-5-14 17:51
文本(以制表符分隔)(*.txt) (Windows)
文本 (Macintosh)
文本(OS/2 或 MS-DOS)
CSV(以逗号分隔)(*.csv) (Windows)
CSV (Macintosh)
CSV(OS/2 或 MS-DOS)

如果需要将工作簿保存为以制表符分隔或以逗号分隔的文本文件,以便在另一个操作系统中使用,请选择合适的转换器以确保制表符、分行符以及其他符号正确的转换。
只保存活动工作表。


2个是一样的道理……

一个是TAB间隔,一个是逗号间隔而已。

txt的把你的逗号改成TAB,也支持公式
作者: cnLiou     时间: 2008-5-14 19:16
与html的格式一致即可. 如下可供考:

@Echo Off

Echo ^<Table border="1"^>>Excel.xls
        REM Title
        Echo ^<TR^>>>Excel.xls
                Echo ^<TD^>Sn^</TD^>>>Excel.xls
                Echo ^<TD^>Name^</TD^>>>Excel.xls
                Echo ^<TD^>Age^</TD^>>>Excel.xls
        Echo ^</TR^>>>Excel.xls
        REM Content
        Echo ^<TR^>>>Excel.xls
                Echo ^<TD^>1^</TD^>>>Excel.xls
                Echo ^<TD^>Liou^</TD^>>>Excel.xls
                Echo ^<TD^>25^</TD^>>>Excel.xls
        Echo ^</TR^>>>Excel.xls
        Echo ^<TR^>>>Excel.xls
                Echo ^<TD^>2^</TD^>>>Excel.xls
                Echo ^<TD^>Tony^</TD^>>>Excel.xls
                Echo ^<TD^>26^</TD^>>>Excel.xls
        Echo ^</TR^>>>Excel.xls
        Echo ^<TR^>>>Excel.xls
                Echo ^<TD^>3^</TD^>>>Excel.xls
                Echo ^<TD^>Eric^</TD^>>>Excel.xls
                Echo ^<TD^>27^</TD^>>>Excel.xls
        Echo ^</TR^>>>Excel.xls
Echo ^</Table^>>>Excel.xls
作者: pykacha     时间: 2008-5-21 17:53
不停地学习中,谢谢大家