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

[文本处理] 批处理如何提取特定字符的行,并复制到EXCEL中?

各位大神,遇到一个难题,帮忙伸出一下援手,
如何提取特定字符哪一行的所有文字,并复制到EXCEL中
例如:
一个文件夹里面有很多的相同类似的文件,A.TXT,B.TXT,C.TXT ....(或者其它后缀文件也能适用)
查找TXT里面是否有菠菜这个特定字符,如果有,则把带菠菜哪一行的字符复制到新创建的EXCEL文本中,首行是TXT文本的文件名,第二行复制带有特定字符的一整行

例子:
A.TXT   C.TXT  里面有菠菜字符

则需要处理为: 生成一个结果EXCEL文件,COPY如下格式:

A
天津市   菠菜   1.5元    张杰
C
西安市 菠菜  1.6元   李帅

本帖最后由 qixiaobin0715 于 2024-11-10 08:51 编辑

格式要求不是太严格的话:
  1. @echo off
  2. (for /f "tokens=* delims==- " %%i in ('find  "中国" *.txt') do echo,%%i)>a.csv
  3. pause
复制代码
保存为ANSI编码

TOP

本帖最后由 aloha20200628 于 2024-11-10 10:32 编辑

回复 1# 司马光2008

以下代码运行结果会生成一个 "结果.txt",execl 可直接用文本格式导入
在当前目录下 *.txt 和 *.lst 文件中搜索包含关键词的所有数据行,未发现则略过该文件,发现则全部写入结果文件...
  1. @echo off &cd.>"结果.txt"
  2. for /f "delims=" %%F in ('dir /b/a-d *.txt *.lst') do (
  3.     findstr /i "菠菜" "%%F">nul&&(echo,%%~nF&findstr /i "菠菜" "%%F")>>"结果.txt") 2>nul
  4. pause&exit/b
复制代码
用 findstr 便于匹配文件中多个关键词,如下式...
  1. @echo off &cd.>"结果.txt"
  2. for /f "delims=" %%F in ('dir /b/a-d *.txt *.lst') do (
  3.     findstr /i "菠菜 番茄 萝卜" "%%F">nul&&(echo,%%~nF&findstr /i "菠菜 番茄 萝卜" "%%F")>>"结果.txt") 2>nul
  4. pause&exit/b
复制代码

TOP

感谢 qixiaobin0715和aloha20200628

TOP

返回列表