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

[文本处理] 批处理和vbs如何返回文本中的某一特定值

[复制链接]
发表于 2017-4-26 13:55:46 | 显示全部楼层 |阅读模式
findbyname.txt内容为:
NB99999 2664978801046
NB0011 EB34024851                    
NB2569 R30972987
NB1234 EB12345678
查询到EB34024851,要返回值为NB0011,即查询到后一个值要返回前一个值的批处理和vbs要如何写?
以下是我写的bat:
  1. @echo off&setlocal enabledelayedexpansion
  2. set F=findbyname.txt
  3. echo 请输入你要查询的号码:
  4. set /p sn=
  5. for /f "tokens=1,2 delims= " %%i in ('type "%f%"') do (
  6. if %%i == "%sn%" ( echo %%i
  7. )else (
  8. echo %%j
  9. )
  10. )
  11. pause
复制代码
可是这个的返回值始终是文本的后一列,要如何改进?并用vbs表示要怎么写?
发表于 2017-4-26 16:23:28 | 显示全部楼层
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. set "F=findbyname.txt"
  4. echo 请输入你要查询的号码:
  5. set /p sn=
  6. for /f "tokens=1,2 delims= " %%i in ('type "%f%"') do (
  7.     if "%%j" == "%sn%" (
  8.         echo,%%i
  9.     )
  10. )
  11. pause
复制代码
 楼主| 发表于 2017-4-26 19:54:07 | 显示全部楼层
多谢,原来是我自己搞错了,把%%j错以为是%%i,请问如何用vbs表示呢?
发表于 2017-4-26 21:55:17 | 显示全部楼层
  1. Dim strFile, strInput

  2. strFile = "1.txt"

  3. Do
  4.     strInput = InputBox("input:")
  5.     If IsEmpty(strInput) Then WSH.Quit()
  6. Loop Until strInput <> ""

  7. Dim fso, objFile, arr
  8. Set fso = CreateObject("Scripting.FileSystemObject")
  9. Set objFile = fso.OpenTextFile(strFile, 1)

  10. While Not objFile.AtEndOfStream
  11.     arr = Split(objFile.ReadLine, " ")
  12.     If UBound(arr) > 0 Then
  13.         If arr(1) = strInput Then MsgBox arr(0)
  14.     End If
  15. Wend

  16. objFile.Close()
  17. Set objFile = Nothing : Set fso = Nothing
复制代码
 楼主| 发表于 2017-4-27 09:00:28 | 显示全部楼层
非常感谢二位帮我解决了这个难题:):)
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-17 16:03 , Processed in 0.016968 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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