中国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
http://bathome.l3.wuyou.com/thread-6921-1-1.html

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
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复

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


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



论坛跳转: