Board logo

标题: 如何用批处理将TXT文件直接转换成XLS文件 [打印本页]

作者: xycoordinate     时间: 2007-2-24 00:29    标题: 如何用批处理将TXT文件直接转换成XLS文件

如何用批处理将TXT文件直接转换成XLS文件

report.txt

  Quote:
1 13  45 0 4500  15615
2 13  45 0 4500  15600
3 26  255 0 25500  15601
4 18  81 0 8100  15602
5 29  188 0 18800  15605
6 25  150 0 15000  15606
7 84  333 12 33900  15609
8 20  105 1 10550  15610
9 26  128 0 12800  15611
10 14  149 0 14900  15612
11 5  33 0 3300  15613
12 0  0  0 0  15616
13 48  190 16 19800  15617
14 321   1702 29 171650   

[ Last edited by xycoordinate on 2007-2-23 at 11:34 AM ]
作者: slore     时间: 2007-2-24 00:47
xls
你用记事本打开是什么格式?
作者: anqing     时间: 2007-2-24 01:32
txt中的数字,能准确给xls文件吗?
作者: slore     时间: 2007-2-24 01:34
格式有规律当然可以。
作者: zh159     时间: 2007-2-24 01:34
现在没时间写代码,给你一个思路:

先将双空格替换为单空格,再将单空格替换为{TAB}+单空格({TAB}:制表符)

然后直接用 Excel 打开该 TXT 文件
作者: slore     时间: 2007-2-24 01:53
看了本来有的xls文档,貌似不是纯文本样子……

那就5楼的模拟输入咯。。。
作者: slore     时间: 2007-2-24 02:40
脚本可以引用这个对象Excel.Application
作者: vkill     时间: 2007-2-24 02:50
这个不可以吧?xls文件用记事本打开是乱码的
作者: amao     时间: 2007-2-24 03:20
sed "s/^[ \t]*//;s/[ \t]\+/\t/g" report.txt> result.xls

sed的下载和使用请用"sed"搜索本论坛

[ Last edited by amao on 2007-2-24 at 03:22 AM ]
作者: NaturalJ0     时间: 2007-2-24 03:27
如果隔着空格或TAB或逗号,倒是可以直接用EXCEL打开TXT文件,EXCEL会问你如何分隔。
PS:按TAB键分隔好,复制到剪贴板,再打开EXCEL粘贴,倒也可行,如果这样的话要用VBS了。
作者: zh159     时间: 2007-2-24 03:56
生成的“test.xls”可以直接用 Excel 打开
@echo off
setlocal EnableDelayedExpansion
cd.>test.xls
for /f "delims=" %%n in (test.txt) do (
  set "str=%%n"
  set "str=!str:  = !"
  set "str=!str: ={TAB} !"
echo !str!
>>test.xls echo !str!
)
pause
{TAB}:键盘TAB制表符

PS:你的数据最后一行“14 321   1702 29 171650   ”是不是有问题,少了第三个数据?

[ Last edited by zh159 on 2007-2-23 at 06:16 PM ]
作者: xycoordinate     时间: 2007-2-24 09:38


  Quote:
Originally posted by zh159 at 2007-2-23 02:56 PM:
生成的“test.xls”可以直接用 Excel 打开

@echo off
setlocal EnableDelayedExpansion
cd.>test.xls
for /f "delims=" %%n in (test.txt) do (
  set "str=%%n"
  set "str=!str:  = !"
  set "str=!str: ={TAB} !"

echo !str!
>>test.xls echo !str!
)
pause

先将双空格替换为单空格,再将单空格替换为{TAB}+单空格({TAB}:制表符)

谢谢!!!
NNNNNN!!!!!!!!!!!!!

还有:

  Quote:
cd.>test.xls

set "str=!str:  = !"
set "str=!str: ={TAB} !"

意思不太明白???
是这个吗?

  Quote:
set /?
环境变量替换已如下增强:

    %PATH:str1=str2%

会扩展 PATH 环境变量,用 "str2" 代替扩展结果中的每个 "str1"。
要有效地从扩展结果中删除所有的 "str1","str2" 可以是空的。
"str1" 可以以星号打头;在这种情况下,"str1" 会从扩展结果的
开始到 str1 剩余部分第一次出现的地方,都一直保持相配。

我直接用tab分割列就OK了!!!!


20070131.txt如下格式,直接更改扩展名为xls,就能如我愿了!!!
1        13         45        0        4500         15615
2        13         45        0        4500         15600
3        26         255        0        25500         15601
4        18         81        0        8100         15602
5        29         188        0        18800         15605
6        25         150        0        15000         15606
7        84         333        12        33900         15609
8        20         105        1        10550         15610
9        26         128        0        12800         15611
10        14         149        0        14900         15612
11        5         33        0        3300         15613
12        0         0         0        0         15616
13        48         190        16        19800         15617
14        321          1702        29        171650

[ Last edited by xycoordinate on 2007-2-23 at 10:53 PM ]
作者: vkill     时间: 2007-2-24 09:39
反过来那?
作者: chainliq     时间: 2007-2-24 10:46
呵呵,这样也简单哈`````

@echo off
type report.txt echo >>report.xls
作者: xycoordinate     时间: 2007-2-24 11:43


  Quote:
Originally posted by chainliq at 2007-2-23 09:46 PM:
呵呵,这样也简单哈`````

@echo off
type report.txt echo >>report.xls



  Quote:
F:\>type report.txt echo >>report.xls

report.txt


系统找不到指定的文件。
处理: echo 时出错。

为何会报错?????

report.xls倒是生成了,但是格式不对!!!
作者: xycoordinate     时间: 2007-2-24 12:13


  Quote:
Originally posted by amao at 2007-2-23 02:20 PM:
sed "s/^[ \t]*//;s/[ \t]\+/\t/g" report.txt> result.xls

sed的下载和使用请用"sed"搜索本论坛

[ Last edited by amao on 2007-2-24 at 03:22 AM ]

厉害!!!
作者: zh159     时间: 2007-2-24 14:37
cd.>test.xls
建立一个空的test.xls文件

set "str=!str:  = !"
(两个空格替换为一个空格)

set "str=!str: ={TAB} !"
(一个空格替换为一个制表符+一个空格,因为论坛不能正确显示制表符,所以用{TAB}代替说明,实际是在{TAB}位置按一下制表符键)