Board logo

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

作者: 司马光2008    时间: 2024-11-9 23:10     标题: 批处理如何提取特定字符的行,并复制到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:38

本帖最后由 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编码
作者: aloha20200628    时间: 2024-11-10 10:23

本帖最后由 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
复制代码

作者: 司马光2008    时间: 2024-11-10 21:53

感谢 qixiaobin0715和aloha20200628




欢迎光临 批处理之家 (http://www.bathome.net/) Powered by Discuz! 7.2