中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 搜索 | 上传 | 帮助 »
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » 如何用批处理将TXT文件直接转换成XLS文件
English/Chinese Fix Translation
作者:
标题: 如何用批处理将TXT文件直接转换成XLS文件 上一主题 | 下一主题
xycoordinate
中级用户




积分 493
发帖 228
注册 2007-2-16
来自 安徽
状态 离线
『楼 主』:  如何用批处理将TXT文件直接转换成XLS文件 使用 LLM 解释/回答一下

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

report.txt

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 ]


2007-2-24 00:29
查看资料  发送邮件  发短消息  网志  OICQ (226308607)  编辑帖子  回复  引用回复
slore
铂金会员





积分 5212
发帖 2478
注册 2007-2-8
状态 离线
『第 2 楼』:   使用 LLM 解释/回答一下

xls
你用记事本打开是什么格式?


2007-2-24 00:47
查看资料  发短消息  网志   编辑帖子  回复  引用回复
anqing
高级用户




积分 859
发帖 413
注册 2006-8-14
状态 离线
『第 3 楼』:   使用 LLM 解释/回答一下

txt中的数字,能准确给xls文件吗?


2007-2-24 01:32
查看资料  发送邮件  发短消息  网志   编辑帖子  回复  引用回复
slore
铂金会员





积分 5212
发帖 2478
注册 2007-2-8
状态 离线
『第 4 楼』:   使用 LLM 解释/回答一下

格式有规律当然可以。


2007-2-24 01:34
查看资料  发短消息  网志   编辑帖子  回复  引用回复
zh159
金牌会员




积分 3687
发帖 1467
注册 2005-8-8
状态 离线
『第 5 楼』:   使用 LLM 解释/回答一下

现在没时间写代码,给你一个思路:

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

然后直接用 Excel 打开该 TXT 文件


2007-2-24 01:34
查看资料  发短消息  网志   编辑帖子  回复  引用回复
slore
铂金会员





积分 5212
发帖 2478
注册 2007-2-8
状态 离线
『第 6 楼』:   使用 LLM 解释/回答一下

看了本来有的xls文档,貌似不是纯文本样子……

那就5楼的模拟输入咯。。。


2007-2-24 01:53
查看资料  发短消息  网志   编辑帖子  回复  引用回复
slore
铂金会员





积分 5212
发帖 2478
注册 2007-2-8
状态 离线
『第 7 楼』:   使用 LLM 解释/回答一下

脚本可以引用这个对象Excel.Application


2007-2-24 02:40
查看资料  发短消息  网志   编辑帖子  回复  引用回复
vkill
金牌会员





积分 4103
发帖 1744
注册 2006-1-20
来自 甘肃.临泽
状态 离线
『第 8 楼』:   使用 LLM 解释/回答一下

这个不可以吧?xls文件用记事本打开是乱码的


2007-2-24 02:50
查看资料  发送邮件  访问主页  发短消息  网志   编辑帖子  回复  引用回复
amao
中级用户





积分 316
发帖 152
注册 2006-6-18
状态 离线
『第 9 楼』:   使用 LLM 解释/回答一下

sed "s/^*//;s/\+/\t/g" report.txt> result.xls

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

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


2007-2-24 03:20
查看资料  发短消息  网志   编辑帖子  回复  引用回复
NaturalJ0
银牌会员




积分 1181
发帖 533
注册 2006-8-14
状态 离线
『第 10 楼』:   使用 LLM 解释/回答一下

如果隔着空格或TAB或逗号,倒是可以直接用EXCEL打开TXT文件,EXCEL会问你如何分隔。
PS:按TAB键分隔好,复制到剪贴板,再打开EXCEL粘贴,倒也可行,如果这样的话要用VBS了。


2007-2-24 03:27
查看资料  发短消息  网志   编辑帖子  回复  引用回复
zh159
金牌会员




积分 3687
发帖 1467
注册 2005-8-8
状态 离线
『第 11 楼』:   使用 LLM 解释/回答一下

生成的“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 ]


2007-2-24 03:56
查看资料  发短消息  网志   编辑帖子  回复  引用回复
xycoordinate
中级用户




积分 493
发帖 228
注册 2007-2-16
来自 安徽
状态 离线
『第 12 楼』:   使用 LLM 解释/回答一下

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!!!!!!!!!!!!!

还有:

cd.>test.xls

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


意思不太明白???
是这个吗?
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 ]


2007-2-24 09:38
查看资料  发送邮件  发短消息  网志  OICQ (226308607)  编辑帖子  回复  引用回复
vkill
金牌会员





积分 4103
发帖 1744
注册 2006-1-20
来自 甘肃.临泽
状态 离线
『第 13 楼』:   使用 LLM 解释/回答一下

反过来那?


2007-2-24 09:39
查看资料  发送邮件  访问主页  发短消息  网志   编辑帖子  回复  引用回复
chainliq
高级用户

学无尽止


积分 635
发帖 244
注册 2006-4-15
来自 广西贵港
状态 离线
『第 14 楼』:   使用 LLM 解释/回答一下

呵呵,这样也简单哈`````

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




学无尽止
2007-2-24 10:46
查看资料  发送邮件  访问主页  发短消息  网志  OICQ (86682419)  编辑帖子  回复  引用回复
xycoordinate
中级用户




积分 493
发帖 228
注册 2007-2-16
来自 安徽
状态 离线
『第 15 楼』:   使用 LLM 解释/回答一下

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

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


<img src="images/smilies/face-sad.png" align="absmiddle" border="0">


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

report.txt


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


为何会报错?????

report.xls倒是生成了,但是格式不对!!!


2007-2-24 11:43
查看资料  发送邮件  发短消息  网志  OICQ (226308607)  编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: