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

[文本处理] 批处理怎么判断每行的第二列为空值的,自动加个1?

[复制链接]
发表于 2015-1-16 09:04:32 | 显示全部楼层 |阅读模式
怎么判断每行的第二列为空值的,自动加个1,列如
文本10万行

sdfgsdgw@163.com----234532dsr
dfgdfhdfh@163.com----
sfdgedfhg@163.com----werwaefq234
w342353xdgfd@163.com----
dfgdfhdfh@163.com----sdgsdfasdadeww



判断----分列第2列为空的,自动添加个123456或者随便加个什么字符加1都可以   实现后
sdfgsdgw@163.com----234532dsr
dfgdfhdfh@163.com----123456
sfdgedfhg@163.com----werwaefq234
w342353xdgfd@163.com----123456
dfgdfhdfh@163.com----sdgsdfasdadeww
这样就达到了目的,请教下高手,怎么弄
发表于 2015-1-16 09:30:09 | 显示全部楼层

  1. @echo off
  2. gawk "BEGIN{FS="----";OFS="----";}{if($2==""){print $1,"123456";}else{print;}}" 1.txt
  3. pause
复制代码
 楼主| 发表于 2015-1-16 09:54:23 | 显示全部楼层
不行啊   gawk是第三方吧     是把要处理的文本改为1.txt吧   我测试了 没作用啊,
----的空没添加任何字符啊
发表于 2015-1-16 09:54:32 | 显示全部楼层
回复 2# yiwuyun


简化:
  1. gawk "BEGIN{FS=OFS="----"}$2=$2?$2:123456" 1.txt > 2.txt
复制代码
 楼主| 发表于 2015-1-16 10:02:47 | 显示全部楼层
OK  以上3楼代码已经完成,,麻烦再请教下

如果
dfgdfhdfh@163.com----sdgsdfasdadeww-----
再加上以上的情况要去掉最后的----
dfgdfhdfh@163.com----sdgsdfasdadeww

因该加个什么代码
发表于 2015-1-16 10:28:27 | 显示全部楼层
回复 5# 649918043
  1. gawk -F "----" "{$2=$2?$2:123456;print $1"----"$2}" 1.txt > 2.txt
复制代码
发表于 2015-1-16 11:37:08 | 显示全部楼层
回复 4# DAIC
还是比较喜欢if...else的方式。嗯,可以用$2直接判断。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-19 20:16 , Processed in 0.018893 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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