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

[文本处理] [已解决]批处理如何删除双引号或提取双引号内的内容?

本帖最后由 flyegg 于 2016-1-27 14:09 编辑

有的文件比如csv文件中有好多双引号“
我想以“作为分隔符,摘取字段。但”怎么转义啊?
或者干脆将”都删了,以逗号为分隔符也行。

比如:test.txt
"123","2 34","345"
我想取345字段。我用^\/都转义不了。

  1. @echo off
  2. for /f tokens^=1^,2^,3delims^=^"^, %%i in (test.txt) do (
  3. echo;%%i  %%j  %%k
  4. )
  5. pause
复制代码
人生是一部书/只有这一页最温暖/读懂它的时候/我们在远方流泪...

TOP

正则表达式很好用的。
去学去写去用才有进步。安装python3代码存为xx.py 双击运行或右键用IDLE打开按F5运行

TOP

  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /f "delims=" %%i in (test.txt) do (
  4. set line=%%i
  5. set line=!line:"=!
  6. echo;!line!
  7. )
  8. pause
复制代码
人生是一部书/只有这一页最温暖/读懂它的时候/我们在远方流泪...

TOP

本帖最后由 /zhqsystem/zhq 于 2016-1-25 21:31 编辑
  1. @echo off
  2. setlocal enabledelayedexpansion
  3. for /f "delims=" %%i in (test.txt) do (
  4. for %%j in ("%%~i")do set "#new=%%~j"
  5. echo,!#new!&rem:延迟变量用法
  6. call echo,%%#new%%&rem:调用脱离延迟变量用法
  7. )
复制代码
这么好的论坛你上哪找,运行测试环境为6.1.7601-64
注:请遵守互联网信息安全,勿用于非法用途

TOP

谢谢大家。我水平太低。
1.回家路上,4楼的看懂了。2楼的看懂了,但不知道for /f tokens^=1^,2^,3delims^=^"^, 中,加这和多^为什么以,觉的这样就行for /f tokens=1,2,3delims=^",不知道那些^是作什么用的。但会用了。
2./zhqsystem/zhq,看不懂。还要学习。

TOP

回复 1# flyegg


    上传样本

TOP

这3种方法都能用,我只是看不懂5楼的。和2楼为什么要那么多的^,还要学习。谢谢

TOP

回复 6# flyegg

目的就是让/f后面的字符串解析成参数,而不是非法字符

TOP

返回列表