找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 26175|回复: 2

[文件操作] 批处理如何统计Excel表格指定列中的指定字符(英文逗号,)的个数/数量

[复制链接]
发表于 2009-5-8 10:06:40 | 显示全部楼层 |阅读模式
本帖最后由 pcl_test 于 2016-8-11 16:14 编辑

我有一个Excel,D列 E列分别是数字和器件,如下图:
25L11, L12, L13, L24, L28, R173,
R386A, R451, R711, L66
R3,
R99, R113, R154, R156, R178, R213, R382, R374, R125, R386, R387, L29, R297, R282
2R350,R351
21R28, R29, R33, R48, R51, R54, R80, R85, R133, R135, R136, R137, R139, R140, R141, R142, R143, R146, R284, R753, R230
5R75,R102,R394,R74,R97,
12R150, R170, R181, R201, R203, R205, R217, R219, R220, R223, R124, R126
13R92, R123, R130, R131, R132, R81, R83, R84, R90, R91, R433, R504, R505

那我想做一个批处理计算E列中的器件总数和D列的数值是否相同,如果不同就暂停执行批处理,并把错误行告知。
我的想法是计算E列中的逗号数+1与D列数值比较,但具体怎么做却没办法,请高手指点一下!
发表于 2009-5-8 18:10:32 | 显示全部楼层
批处理不能直接对excel文件进行操作,所以应先将要比对的内容复制到文本中再用批处
理进行比对(测试时请将代码中的[tab]字符换成实际的tab键):
  1. @echo off&setlocal enabledelayedexpansion
  2. rem 先复制两列内容到a.txt
  3. for /f "tokens=1,2 delims=[tab]" %%a in (a.txt) do (
  4.      set /a num+=1
  5.      for %%c in (%%b) do set /a n+=1
  6.      if %%a neq !n! call :lp
  7.      set /a n=0
  8. )
  9. pause>nul&goto :eof
  10. :lp
  11. echo %num%行出错&pause>nul
复制代码
发表于 2016-8-11 16:51:35 | 显示全部楼层
vbs
  1. Set ExcelApp = CreateObject("Excel.Application")
  2. ExcelApp.Visible = True
  3. Set objBook = ExcelApp.Workbooks.Open("C:\Users\Administrator\Desktop\文件列表\测试.xls")
  4. ExcelApp.WorkSheets(1).Activate
  5. rowcount =objBook.ActiveSheet.UsedRange.Rows.Count
  6. s=""
  7. For i=1 to rowcount
  8.     d = objBook.ActiveSheet.Cells(i, 4).value
  9.     e = UBound(split(objBook.ActiveSheet.Cells(i, 5).value, ","))+1
  10.     If d <> e Then  s=s&"第"&i&"行:D列"&d&" E列"&e&vbCrLf
  11. Next
  12. Msgbox s
  13. objBook.Close
  14. ExcelApp.Quit
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-21 06:09 , Processed in 0.030057 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表