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

[文本处理] [已解决]批处理从1.csv中取出.txt、.ini、.bat、.vbs的完整路径(含扩展名)

[复制链接]
发表于 2022-9-20 08:47:58 | 显示全部楼层 |阅读模式
从1.csv中取出.txt、.ini、.bat、.vbs的完整路径(含扩展名),保存为1.txt
完美解决了:
  1. @echo off
  2. (for /f "delims=" %%i in ('findstr "\.txt \.ini \.bat \.vbs" 1.csv') do (
  3.     for /f tokens^=17^ delims^=^" %%j in (%%i) do (
  4.         for /f "delims=-" %%k in ("%%j") do echo,%%k
  5.     )
  6. ))>1.txt
复制代码
pause[/code]*****************************************************************
下面是不能正确输出的1.csv
https://pan.baidu.com/s/1D0-KYijTpeT6mD2UXB3r-g
发表于 2022-9-20 09:35:45 | 显示全部楼层
试一下如下指令

  1. for /f "tokens=1* delims=." %a in ('findstr /i "\<.*.exe" 1.txt') do @where %~a.exe
复制代码

评分

参与人数 1技术 +1 收起 理由
yyz219 + 1 乐于助人

查看全部评分

 楼主| 发表于 2022-9-20 09:37:09 | 显示全部楼层
试一下如下指令
hfxiang 发表于 2022-9-20 09:35



    我试一试先,辛苦了
 楼主| 发表于 2022-9-20 09:42:34 | 显示全部楼层
试一下如下指令
hfxiang 发表于 2022-9-20 09:35



    不行,闪一下,也没有生成1.txt
发表于 2022-9-20 09:53:24 | 显示全部楼层
回复 4# yyz219


2楼的指令在CMD窗口下执行,不是写在bat中执行,输入文件为1.txt,直接在屏幕上输出。

写在bat中执行的指令如下(以下指令提取的是.exe文件,其它的需自行改动):

  1. @rem 保存文件编码为ANSI
  2. @echo 执行中请等候......
  3. @(for /f "tokens=1* delims=." %%a in ('findstr /i "\<.*.exe" 1.csv') do @where "%%~a.exe")>1.txt 2>nul
  4. @echo
  5. @echo 执行完毕......
复制代码

评分

参与人数 1技术 +1 收起 理由
yyz219 + 1 能够正确输出,麻烦修改为批处理

查看全部评分

发表于 2022-9-20 10:01:53 | 显示全部楼层
最好能在网盘中传一份CSV文件看看。

评分

参与人数 1技术 +1 收起 理由
yyz219 + 1 上传了,麻烦看一下

查看全部评分

 楼主| 发表于 2022-9-20 10:32:32 | 显示全部楼层
本帖最后由 yyz219 于 2022-9-20 10:34 编辑
最好能在网盘中传一份CSV文件看看。
qixiaobin0715 发表于 2022-9-20 10:01



https://pan.baidu.com/s/1AhboSmHTB7sLigWmDFuppw
 楼主| 发表于 2022-9-20 10:43:54 | 显示全部楼层
本帖最后由 yyz219 于 2022-9-20 10:48 编辑
回复  yyz219


2楼的指令在CMD窗口下执行,不是写在bat中执行,输入文件为1.txt,直接在屏幕上输出。
...
hfxiang 发表于 2022-9-20 09:53



    我要提取的是文中粉红色的(这个是变化的)
发表于 2022-9-20 10:55:58 | 显示全部楼层
回复 8# yyz219


   
直接在CMD窗口下试试如下指令:

  1. @(for /f "tokens=10 delims=," %a in (1.csv) do @for /f %b in ('echo %~a^|findstr /i ".txt .ini .bat .vbs"')  do @echo "%~b")>1.txt 2>nul
复制代码

评分

参与人数 1技术 +1 收起 理由
yyz219 + 1 能够正确输出,麻烦修改为批处理

查看全部评分

发表于 2022-9-20 10:57:30 | 显示全部楼层
本帖最后由 qixiaobin0715 于 2022-9-20 11:16 编辑

回复 7# yyz219
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for %%x in (.txt .ini .bat .vbs) do set %%x=true
  4. (for /f "delims=" %%i in (1.csv) do (
  5.     for %%j in (%%i) do (
  6.         set str=%%j
  7.     )
  8.     for /f "delims=-" %%k in (!str!) do (
  9.         if defined %%~xk echo,%%k
  10.     )
  11. ))>1.txt
  12. pause
复制代码
看看显示是否正确

评分

参与人数 1技术 +1 收起 理由
yyz219 + 1 再麻烦一下,让它在生成1.txt

查看全部评分

 楼主| 发表于 2022-9-20 11:13:12 | 显示全部楼层
回复  yyz219 看看显示是否正确
qixiaobin0715 发表于 2022-9-20 10:57



    屏幕能够正确显示

再麻烦一下,让它在生成1.txt

谢谢
发表于 2022-9-20 11:16:31 | 显示全部楼层
回复 11# yyz219
已修改
 楼主| 发表于 2022-9-20 11:20:08 | 显示全部楼层
回复  yyz219
已修改
qixiaobin0715 发表于 2022-9-20 11:16



    非常感谢,完美解决
发表于 2022-9-20 16:37:44 | 显示全部楼层
如果数据像你提供的那么规整的话,这样效率应当更高些:
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. (for /f "delims=" %%i in ('findstr "\.txt \.ini \.bat \.vbs" 1.csv') do (
  4.     for %%j in (%%i) do set str=%%j
  5.     for /f "delims=-" %%k in (!str!) do echo,%%k
  6. ))>1.txt
  7. pause
复制代码
未经测试。

评分

参与人数 1技术 +1 收起 理由
yyz219 + 1 乐于助人

查看全部评分

 楼主| 发表于 2022-9-20 21:33:44 | 显示全部楼层
如果数据像你提供的那么规整的话,这样效率应当更高些:未经测试。
qixiaobin0715 发表于 2022-9-20 16:37



    非常感谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-19 15:48 , Processed in 0.026761 second(s), 9 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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