标题: [文本处理] [已解决]批处理如何删除双引号或提取双引号内的内容? [打印本页]
作者: 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
- @echo off
- for /f tokens^=1^,2^,3delims^=^"^, %%i in (test.txt) do (
- echo;%%i %%j %%k
- )
- pause
复制代码
作者: codegay 时间: 2016-1-25 19:16
正则表达式很好用的。
作者: 回家路上 时间: 2016-1-25 19:21
- @echo off
- setlocal enabledelayedexpansion
- for /f "delims=" %%i in (test.txt) do (
- set line=%%i
- set line=!line:"=!
- echo;!line!
- )
- pause
复制代码
作者: /zhqsystem/zhq 时间: 2016-1-25 21:29
本帖最后由 /zhqsystem/zhq 于 2016-1-25 21:31 编辑
- @echo off
- setlocal enabledelayedexpansion
- for /f "delims=" %%i in (test.txt) do (
- for %%j in ("%%~i")do set "#new=%%~j"
- echo,!#new!&rem:延迟变量用法
- call echo,%%#new%%&rem:调用脱离延迟变量用法
- )
复制代码
作者: 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 |