标题: 求教如何用批处理使得txt文件转换未csv文件?? [打印本页]
作者: q1a2z3q1a2z3 时间: 2011-6-24 21:14 标题: 求教如何用批处理使得txt文件转换未csv文件??
我有一个txt文件的通讯录,要导到手机需要csv格式,用批处理怎样弄
在网站找到如下代码,使用不了 提示sed不是内部命令,也不是外部命令,求解!!!
@echo off
for %%a in (*.txt) do >"%%~na_new.csv" sed "s/|/,/g;s/,\([0-9]\{11,\}\)/,'\1/g" "%%~a"
pause
http://www.bathome.net/thread-2305-1-180.html
作者: CrLf 时间: 2011-6-24 21:51
sed确实是第三方命令,需要预先下载sed程序文件。不过大概看了下,感觉这个用纯批也可以做到
题外汗一个,楼主的名字差点让我以为此贴是广告...
作者: q1a2z3q1a2z3 时间: 2011-6-24 22:15
版主能上个 纯批的文件吗?
作者: CrLf 时间: 2011-6-24 22:57
2楼的话好像说太满了...楼主可否给出前后对比的样本文件?具体情况具体分析,个人感觉看起来有点曲折但是纯批应可实现
作者: batman 时间: 2011-6-25 09:51
csv就是各列用,格开的文件,这个批很容易办到的。。。
下面的代码请写测试:- @echo off&setlocal enabledelayedexpansion
- for %%a in (*.txt) do (
- (for /f "usebackq delims=" %%b in ("%%a") do (
- set "str=%%b"&set "str=!str: =,!"
- echo !str: =,!
- ))>"%%~na.csv"
- del /q "%%a"
- )
复制代码
作者: CrLf 时间: 2011-6-25 11:59
5# batman
可是这段正则感觉没有太好的办法实现呀“s/,\([0-9]\{11,\}\)/,'\1/g”
作者: batman 时间: 2011-6-25 12:04
6# zm900612
具体还要楼主给出详细的文本示例来定,从正则上看出是只取每个通讯人的第一个手机号码。。。
作者: Batcher 时间: 2011-6-25 12:58
命令行工具 sed.exe 下载地址:
http://bbs.bathome.net/thread-1114-1-1.html
欢迎光临 批处理之家 (http://www.bathome.net/) |
Powered by Discuz! 7.2 |