中国DOS联盟论坛

中国DOS联盟

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

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

游客:  注册 | 登录 | 命令行 | 搜索 | 上传 | 帮助 »
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » [已结]请教问题 : P是否可以将 excel *.xls 转成 *.txt 吗?
作者:
标题: [已结]请教问题 : P是否可以将 excel *.xls 转成 *.txt 吗? 上一主题 | 下一主题
pdanniel66
初级用户





积分 68
发帖 64
注册 2009-5-23
状态 离线
『楼 主』:  [已结]请教问题 : P是否可以将 excel *.xls 转成 *.txt 吗?

请教问题 : P是否可以将 excel *.xls 转成 *.txt 吗? [ Last edited by pdanniel66 on 2010-6-5 at 16:24 ]


2010-6-5 10:18
查看资料  发送邮件  发短消息  网志   编辑帖子  回复  引用回复
vwase
新手上路





积分 7
发帖 4
注册 2010-5-20
状态 离线
『第 2 楼』:  

不可以.他们的编码不同,没法当做简单的文本处理


2010-6-5 12:07
查看资料  发短消息  网志   编辑帖子  回复  引用回复
HAT
版主





积分 9023
发帖 5017
注册 2007-5-31
状态 离线
『第 3 楼』:  

VBS可以




2010-6-5 13:41
查看资料  发短消息  网志   编辑帖子  回复  引用回复
pdanniel66
初级用户





积分 68
发帖 64
注册 2009-5-23
状态 离线
『第 4 楼』:  

Reference link as below bathome.l3.wuyou.com ... Reference the above link and share my code -- the batch and vbs as below Transfer *.xls to *.txt (1) main batch scripts ==> main01.bat del hhh.txt call xzt.vbs "123.xls" hhh.txt call del_blank.bat (2) xzt.vbs '另存工作表为txt文件,并将空值替换为# dim hang,lie,counter,counter1 '声明变量 on error resume next '忽略错误 '设置对象 set wshshell=createobject ("wscript.shell") path=wshshell.currentdirectory '当前路径 set objexcel=createobject ("excel.application") set objworks=objexcel.workbooks.open (path&"\"&wscript.arguments(0)) 'arguments(0)表示参数1 set objfso=createobject("scripting.filesystemobject") set objtext=objfso.opentextfile(path&"\"&wscript.arguments(1),2,true) 'arguments(1)表示参数2 objexcel.worksheets(1).activate '获取工作表有效总行列数,但工作表的第一行和第一列不得有空值 counter=0 do counter=counter+1 loop until objexcel.cells(1,counter).value="" lie=counter-1:counter=0 do counter=counter+1 loop until objexcel.cells(counter,1).value="" hang=counter-1:counter=0 '读取工作表数据并将空值替换为# for counter=1 to hang for counter1=1 to lie if objexcel.cells(counter,counter1).value="" then strexcel=strexcel&" #" else strexcel=strexcel&" "&objexcel.cells(counter,counter1).value end if next strexcel=strexcel&vbcrlf next objtext.write strexcel objtext.close objworks.close '清空对象,释放内存 set objtext=nothing set objfso=nothing set objworks=nothing set objexcel=nothing set wshshell=nothing (3) del_blank.bat ( delete the blank per line ) @echo off del hhh_fin.txt for /f "tokens=* delims= " %%s in (hhh.txt) do call :str %%s >> hhh_fin.txt :str echo %* [ Last edited by pdanniel66 on 2010-6-5 at 16:23 ]


2010-6-5 16:11
查看资料  发送邮件  发短消息  网志   编辑帖子  回复  引用回复

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


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



论坛跳转: