Board logo

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

作者: flyegg    时间: 2016-1-25 17:15     标题: [已解决]批处理如何删除双引号或提取双引号内的内容?

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

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

比如:test.txt
"123","2 34","345"
我想取345字段。我用^\/都转义不了。
作者: 回家路上    时间: 2016-1-25 19:07

  1. @echo off
  2. for /f tokens^=1^,2^,3delims^=^"^, %%i in (test.txt) do (
  3. echo;%%i  %%j  %%k
  4. )
  5. pause
复制代码

作者: codegay    时间: 2016-1-25 19:16

正则表达式很好用的。
作者: 回家路上    时间: 2016-1-25 19:21

  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
复制代码

作者: /zhqsystem/zhq    时间: 2016-1-25 21:29

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

作者: flyegg    时间: 2016-1-26 11:23

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

回复 1# flyegg


    上传样本
作者: flyegg    时间: 2016-1-26 16:45

这3种方法都能用,我只是看不懂5楼的。和2楼为什么要那么多的^,还要学习。谢谢
作者: pcl_test    时间: 2016-1-26 20:15

回复 6# flyegg

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




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