设为首页 收藏本站
查看: 1659|回复: 0

windows批处理(shell脚本)获取指定行的文本

[复制链接]

尚未签到

发表于 2017-5-15 13:36:14 | 显示全部楼层 |阅读模式
1. 读取指定行

1.1 方法一
  从Objs.out文件中的第3行开始的内容取出存到0.txt中。

@echo off
if exist Objs.out (
rem get lines from the 3rd line
set n=1
SetLocal EnableDelayedExpansion
for /f "delims=" %%i in (Objs.out) do (
echo %%i
if !n! geq 3 (
echo %%i >> 0.txt
) else (
echo not matching...
)
set /a n=!n!+1
)
) else (
echo not found Objs.out
)

1.2 方法二

也可以使用for语句的skip,从第3行开始读取:
for /f "skip=2 delims=" %%i in (objs.out) do (
...
)

2. 获取指定列或指定字符

2.1 获取指定列

默认用空格作为分隔符。构造语句存入1_DDL.txt中。
if exist 0.txt (
for /f "tokens=1,2" %%i in (0.txt) do (
echo %%i
echo %%j
if %%j == T (
echo show table %%i; >> 1_DDL.txt
) else (
if %%j == V (
echo show view %%i; >> 1_DDL.txt
)
)
)
) else (
echo not found 0.txt
)
上述采用tokens获取的方法,在多数情况下很好用。考虑另外一种情况,若某一列中含有空格,则无法使用这种方法了。可采用2.2中的方法。


2.2 获取指定字符

示例代码中给出了获取某行最后一个字符和开头30个字符的写法:
for /f "skip=2 delims=" %%i in (objs.out) do (

endlocal
set ii=%%i

SetLocal EnableDelayedExpansion
echo !ii!
rem echo !ii:~-1!
if !ii:~-1! == T (
echo drop table hadoop."!ii:~0,30!"; >> drop.sql
rem echo show stats values on hadoop."%%i"; >> drop.sql
) else (
if !ii:~-1! == V (
echo drop view hadoop."!ii:~0,30!"; >> drop.sql
) else (
if !ii:~-1! == O (
echo drop table hadoop."!ii:~0,30!"; >> drop.sql
)
)
)        
)



注意:endlocal和SetLocal之间的代码,之所以写在之间,是为了 处理特殊字符感叹号,在setlocal的情况下,感叹号默认会被忽略。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-377769-1-1.html 上篇帖子: shell脚本 查看还有多少天过生日 下篇帖子: 用shell命令分割大日志文件
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

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