[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文本处理] [已解决]批处理怎样查找文本不定行指定内容并输出?

要查找的文本内容片断:
Basic:
  User access index             : 854
  State                         : Used
  User name                     : zhangsan
  User access status1           : OK
  User access status2           : OK
  User access PeVlan/CeVlan     : 2112/1120
  User-Group                    : -
AAA:
  Action flag                   : Idle
  Authen state                  : Authed
  Author state                  : Idle

Basic:
  User access index             : 231
  State                         : Used
  User name                     : huangli
  User access status1           : OK
  User access status2           : OK
  User access PeVlan/CeVlan     : 2372/6490
  User-Group                    : -
AAA:
  Action flag                   : Idle
  Authen state                  : Authed
  Author state                  : Idle

Basic:
  User access index             : 251
  State                         : Used
  User name                     : liliang
  User access status1           : OK
  User access status2           : OK
  User access PeVlan/CeVlan     : 3111/2643
  User-Group                    : -
AAA:
  Action flag                   : Idle
  Authen state                  : Authed
  Author state                  : Idle

Basic:
  User access index             : 104
  State                         : Used
  User name                     : sunqian
  User access status1           : OK
  User access status2           : OK
  User access PeVlan/CeVlan     : 1128/3243
  User-Group                    : -
AAA:
  Action flag                   : Idle
  Authen state                  : Authed
  Author state                  : Idle

想要得到的结果(输出到csv表格文件):
zhangsan,2112/1120
huangli,2372/6490
liliang,3111/2643
sunqian,1128/3243

即:查找User name和User access PeVlan/CeVlan冒号后面的内容,成对输出(Basic和AAA块成对出现属于一个文本域)
小弟只能单行处理,资历较浅,无法成对输出,帮小弟一把,谢啦老大
1

评分人数

    • Batcher: 感谢给帖子标题标注[已解决]字样PB + 2

回复 2# terse


    成功啦 感谢老大帮忙,我再好好研究研究你的代码

TOP

  1. @echo off&setlocal enabledelayedexpansion
  2. set filename="data.txt"
  3. set "find=findstr /ic:"User name" /c:"User access PeVlan/CeVlan""
  4. for /f "tokens=1* delims=:" %%i in ('%find% %filename%')do (
  5.     if defined str (
  6.        echo !str!,%%j
  7.        set str=
  8.     ) else set str=%%j
  9. )
  10. pause
复制代码
1

评分人数

TOP

返回列表