|
loquat
初级用户
积分 81
发帖 80
注册 2009-8-30
状态 离线
|
『楼 主』:
求一个对比Excel文件的批处理bat vbs随便什么都行
两个xls文件的前两列完全一致。只有第三列不同。并且第三列所有行只有6种内容。
要求将a.xls和b.xls的内容作对比,一行为一项,统计出变化的项的数量,并导出内容到txt或者xls也行。
内容格式例如下:
a.xls
A B C
000001 发展A 保留意见
000002 进步B --
000003 流*动C 带强调事项段的无保留意见
b.xls
A B C
000001 发展A --
000002 进步B 保留意见
000003 流*动C 带强调事项段的无保留意见
要求最后的结果是:
c.txt
A B C D
000001 发展A 保留意见 --
000002 进步B -- 保留意见
C行的6种内容如下:
“标准无保留意见”可记为0;“带强调事项段的无保留意见”可记为1;“无法表示意见”可记为2;“保留意见”可记为3;“否定意见”可记为4;“未披露审计意见类型”可记为5;“--”可记为6
不知道这个难不难,好像从来没见过这种批处理。。。
大侠们帮帮忙,说说可以怎么实现,只要可以实现不管怎么弄都行。
|
|
2010-3-30 12:36 |
|
|
Hanyeguxing
银牌会员
正在学习中的菜鸟...
积分 1039
发帖 897
注册 2009-3-1 来自 在地狱中仰望天堂
状态 离线
|
|
2010-3-30 12:56 |
|
|
loquat
初级用户
积分 81
发帖 80
注册 2009-8-30
状态 离线
|
『第
3 楼』:
谢谢兄弟,那我先去学学这个怎么用。。。
[ Last edited by loquat on 2010-3-30 at 13:06 ]
|
|
2010-3-30 13:05 |
|
|
qinchun36
高级用户
据说是李先生
积分 609
发帖 400
注册 2008-4-23
状态 离线
|
『第
4 楼』:
Dim xls1, xls2, valMap, fso, excel, wbs, sht1, sht2, i, n, result, resultString
xls1 = "C:\Documents and Settings\issuser\桌面\a.xls"
xls2 = "C:\Documents and Settings\issuser\桌面\b.xls"
result = "不同的地方.txt"
Set fso = WScript.CreateObject("Scripting.FileSystemObject")
Set valMap = WScript.CreateObject("Scripting.Dictionary")
With valMap
.Add "标准无保留意见", 0
.Add "带强调事项段的无保留意见", 1
.Add "无法表示意见", 2
.Add "保留意见", 3
.Add "否定意见", 4
.Add "未披露审计意见类型", 5
.Add "--", 6
End With
Set excel = WScript.CreateObject("Excel.Application")
Set wbs = excel.Application.Workbooks
wbs.Open xls1
wbs.Open xls2
Set sht1 = wbs.Item(1).Sheets(1)
Set sht2 = wbs.Item(2).Sheets(1)
i = 1
n = 0
resultString = "A" & vbTab & "B" & vbTab & "C" & vbTab & "D"
Do
If a(i, 3) <> b(i, 3) Then
resultString = resultString & vbNewLine & _
a(i, 1) & vbTab & a(i, 2) & vbTab & c(a(i, 3)) & vbTab & c(b(i, 3))
n = n + 1
End If
i = i + 1
Loop Until sht1.Cells(i, 3) = ""
resultString = "总共有 " & n & " 项不同。" & vbNewLine & vbNewLine & resultString
fso.CreateTextFile(result, True).Write resultString
excel.Quit
MsgBox "比较结果保存到了 " & vbCrLf & vbCrLf & fso.GetFile(result).Path, 64, "完成"
Function a(i, j)
a = sht1.Cells(i, j).Value
End Function
Function b(i, j)
b = sht2.Cells(i, j).Value
End Function
Function c(s)
Dim temp
temp = valMap(s)
If temp = "" Then temp = s
c = temp
End Function [ Last edited by qinchun36 on 2010-3-30 at 16:17 ]
|
┏━━━━━━┓
┃据说是李先生┃
┠──────┨
┃*ntRSS┃
┗━━━━━━┛ |
|
2010-3-30 14:04 |
|
|
loquat
初级用户
积分 81
发帖 80
注册 2009-8-30
状态 离线
|
『第
5 楼』:
Quote: | Originally posted by qinchun36 at 2010-3-30 14:04: |
|
....
感谢大侠出手帮助!
还能不能对得出的txt文件再分别按C列和D列做排序处理?
按0->6的顺序,谢谢。
还是这边气氛好,我在verybat那边发的帖都没人理睬我!不过也怪我自己太菜了。就知道成天收藏别人的批处理,从来没自己尝试写过。。。
现在的文件已经成了这样。。。
Quote: | 总共有 123 项不同。
A B C D
000017 SST中华A 3 0
000028 一致药业 3 0
000030 *ST盛润A 3 0
000033 新都酒店 3 0
000045 深纺织A 0 3
000048 ST康达尔 3 0
000058 深赛格 3 0
000150 宜华地产 0 2
000404 华意压缩 3 0
000410 沈阳机床 0 3 |
|
[ Last edited by loquat on 2010-3-30 at 15:29 ]
附件
1: 2000-2001.rar (2010-3-30 14:50, 40.73 K,下载次数: 6)
|
|
2010-3-30 14:50 |
|
|
qinchun36
高级用户
据说是李先生
积分 609
发帖 400
注册 2008-4-23
状态 离线
|
『第
6 楼』:
上面的代码没有注意数有多少条改变了,已经重新修改了一个小地方。
排序excel里面就有的,这个结果里面的文本是用 Tab 分隔的,
全选复制文本,新建一个excel表,直接CTRL+V粘贴到里面就可以。
然后点“排序和筛选”的“自定义排序”,在这个界面就可以操作了,还可以添加排序条件。
[ Last edited by qinchun36 on 2010-3-30 at 16:16 ]
附件
1: excel_sort.GIF (2010-3-30 16:09, 17.75 K)
|
┏━━━━━━┓
┃据说是李先生┃
┠──────┨
┃*ntRSS┃
┗━━━━━━┛ |
|
2010-3-30 16:09 |
|
|
loquat
初级用户
积分 81
发帖 80
注册 2009-8-30
状态 离线
|
『第
7 楼』:
Quote: | Originally posted by qinchun36 at 2010-3-30 16:09:
上面的代码没有注意数有多少条改变了,已经重新修改了一个小地方。
排序excel里面就有的,这个结果里面的文本是用 Tab 分隔的,
... |
|
但是用Excel按C排序后好像ABD行没有对应变换顺序哦?
|
|
2010-3-30 17:02 |
|
|
qinchun36
高级用户
据说是李先生
积分 609
发帖 400
注册 2008-4-23
状态 离线
|
『第
8 楼』:
.....
excel 基本操作啊,不要去点哪一列,全选之后再排序
|
┏━━━━━━┓
┃据说是李先生┃
┠──────┨
┃*ntRSS┃
┗━━━━━━┛ |
|
2010-3-30 17:25 |
|
|
loquat
初级用户
积分 81
发帖 80
注册 2009-8-30
状态 离线
|
『第
9 楼』:
囧,我以为我电脑算是入门了,没想到还是这么菜啊。
看来水还是很深,继续加油。。。
|
|
2010-3-30 17:33 |
|
|
loquat
初级用户
积分 81
发帖 80
注册 2009-8-30
状态 离线
|
『第
10 楼』:
大侠还能顺手给个没有变化的项目列表不?
|
|
2010-3-30 17:36 |
|
|
Hanyeguxing
银牌会员
正在学习中的菜鸟...
积分 1039
发帖 897
注册 2009-3-1 来自 在地狱中仰望天堂
状态 离线
|
『第
11 楼』:
@echo off&setlocal enabledelayedexpansion
for /f "tokens=1-3 delims= " %%a in (2000.txt) do set "%%a%%b=%%c"
for /f "tokens=1-3 delims= " %%d in (2001.txt) do (
if not "!%%d%%e!"=="%%f" (set/a n+=1
call :i !%%d%%e!
set d=!i!
call :i %%f
set f=!i!
echo %%d %%e !d! !f!))>>输出文件.txt
echo 总共有 %n% 不同。>>输出文件.txt
exit
:i
set i=%1
set i=%i:标准无保留意见=0%
set i=%i:带强调事项段的无保留意见=1%
set i=%i:无法表示意见=2%
set i=%i:保留意见=3%
set i=%i:否定意见=4%
set i=%i:未披露审计意见类型=5%
set i=%i:--=6% 将两个xls文件用excel 打开,复制有效内容到2000.txt和2001.txt中。
注意,批脚本中出现的连续空格实际是一个制表符。
if not "!%%d%%e!"=="%%f" (set/a n+=1 中去掉not得到的就是相同内容的列表
[ Last edited by Hanyeguxing on 2010-3-30 at 17:51 ]
|
批处理之家 http://bbs.bathome.net/forum-5-1.html |
|
2010-3-30 17:48 |
|
|
Hanyeguxing
银牌会员
正在学习中的菜鸟...
积分 1039
发帖 897
注册 2009-3-1 来自 在地狱中仰望天堂
状态 离线
|
『第
12 楼』:
如果不需要替换,那么只用
findstr /x /g:2000.txt 2001.txt >temp.txt 就可以生成。
如果要得到相同部分且需要替换代码则:
@echo off&setlocal enabledelayedexpansion
findstr /x /g:2000.txt 2001.txt >temp.txt
for /f "delims=" %%i in (temp.txt) do (set i=%%i
set i=!i:标准无保留意见=0!
set i=!i:带强调事项段的无保留意见=1!
set i=!i:无法表示意见=2!
set i=!i:保留意见=3!
set i=!i:否定意见=4!
set i=!i:未披露审计意见类型=5!
set i=!i:--=6!
echo !i!)>>相同.txt
del /q temp.txt 如果同时需要按代码陪列顺序,则可以:
@echo off&setlocal enabledelayedexpansion
findstr /x /g:2000.txt 2001.txt >temp.txt
for /f "tokens=1-3 delims= " %%a in (temp.txt) do (set i=%%c
set i=!i:标准无保留意见=0!
set i=!i:带强调事项段的无保留意见=1!
set i=!i:无法表示意见=2!
set i=!i:保留意见=3!
set i=!i:否定意见=4!
set i=!i:未披露审计意见类型=5!
set i=!i:--=6!
set "hanye_!i!%%a=%%b")
for /f "tokens=1,2 delims==" %%i in ('set^|find /i "hanye_"') do (set i=%%i
echo !i:~7! %%j !i:~6,1!)>>相同.txt
del /q temp.txt 注意,批脚本中出现的连续空格实际是一个制表符。
[ Last edited by Hanyeguxing on 2010-3-30 at 18:18 ]
|
批处理之家 http://bbs.bathome.net/forum-5-1.html |
|
2010-3-30 18:02 |
|
|
loquat
初级用户
积分 81
发帖 80
注册 2009-8-30
状态 离线
|
『第
13 楼』:
风舞九天果然神人!感谢两位大力帮助,问题已经完美解决,我帮的那位MM很高兴。。。
嘿嘿。。。
|
|
2010-3-30 18:21 |
|
|
qinchun36
高级用户
据说是李先生
积分 609
发帖 400
注册 2008-4-23
状态 离线
|
『第
14 楼』:
有一行是 If a(i, 3) <> b(i, 3) Then
改成 If a(i, 3) = b(i, 3) Then 就是相同的了
|
┏━━━━━━┓
┃据说是李先生┃
┠──────┨
┃*ntRSS┃
┗━━━━━━┛ |
|
2010-3-30 18:34 |
|
|
loquat
初级用户
积分 81
发帖 80
注册 2009-8-30
状态 离线
|
『第
15 楼』:
为了帮助小弟泡MM,两位大侠可能还要再关注下此贴。同样的数据她还要得出其他的比较结果。
先感谢两位。。。
[ Last edited by loquat on 2010-3-30 at 22:30 ]
|
|
2010-3-30 22:26 |
|