Chinaunix

标题: 读取文件的某一行,并分解字符串 [打印本页]

作者: The_X    时间: 2014-09-25 15:17
标题: 读取文件的某一行,并分解字符串
本帖最后由 The_X 于 2014-09-25 15:35 编辑

要读取的文件:temp.txt,
文件内容为第一行是:0m;1m;2m;0s;1s;2s;
第二行是:10.10.10.30;10.10.10.31;10.10.10.32;10.10.10.33;10.10.10.60;10.10.10.61;10.10.10.62;

第一步:读取第一行,然后根据;分解
第二步:去读第二行,去掉最后一个;    并将去掉;后的字符串赋给namesrv

求解答

可能没描述清楚,

这样说吧,读取一个文件temp.txt ,把第一行根据;将其分解并输出。把第二行最后一个;去掉并输出
作者: bulletmarquis    时间: 2014-09-25 15:19
本帖最后由 bulletmarquis 于 2014-09-25 15:20 编辑

namesrv是啥?
你第一行有6列,第二行有7列,之间有什么联系?
第一行分解以后要用来做啥?
作者: ly5066113    时间: 2014-09-25 15:22
回复 1# The_X


说你想做什么,不要说你想怎么做。
作者: The_X    时间: 2014-09-25 15:25
回复 2# bulletmarquis


    第一行列数不一定,需要将其分解,例如分解出来第一个是0m,那么就需要一个目录是/opt/0m
第二行不用分解,需要将最后一个;去掉,然后写到第一行分解出来的目录下的一个文件里。

最后结果是:
把10.10.10.30;10.10.10.31;10.10.10.32;10.10.10.33;10.10.10.60;10.10.10.61;10.10.10.62分别写到
/opt/0m/test.txt
/opt/1m/test.txt
/opt/2m/test/txt
.......
作者: bulletmarquis    时间: 2014-09-25 15:27
回复 4# The_X


    目录已建好了么?
   文件名固定么?
   循环放到每个目录下,还是随机放?
作者: yestreenstars    时间: 2014-09-25 15:31
一头雾水~{:2_177:}
作者: The_X    时间: 2014-09-25 15:33
回复 5# bulletmarquis


这样描述吧,读取一个文件temp.txt ,把第一行根据;将其分解并输出。把第二行最后一个;去掉并输出

作者: bulletmarquis    时间: 2014-09-25 15:35
  1. awk -vRS=';' -F'.' '/^$/{next}NF==1{a[++i]=$0;next}{_cmd_="echo \""$0"\" >> dir/"a[NR%i+1];print _cmd_}' file
  2. echo "10.10.10.30" >> dir/1m
  3. echo "10.10.10.31" >> dir/2m
  4. echo "10.10.10.32" >> dir/0s
  5. echo "10.10.10.33" >> dir/1s
  6. echo "10.10.10.60" >> dir/2s
  7. echo "10.10.10.61" >> dir/0m
  8. echo "10.10.10.62" >> dir/1m
复制代码
不知道LZ是不是要这样的效果,如果是,则把print _cmd_改成_cmd_|getline;close(_cmd_)
作者: ly5066113    时间: 2014-09-25 15:43
回复 4# The_X


try:
  1. awk -F \; '{getline v;sub(/;$/,"",v);for(i=1;i<NF;i++){p="/opt/"$i;system("mkdir "p);print v>p"/test.txt"}}' temp.txt
复制代码

作者: The_X    时间: 2014-09-25 15:46
回复 8# bulletmarquis


    第一行好长,,,没看明白。。。
我重新说一下问题吧:
在一个shell脚本中要读取文件temp.txt,
首先取出第一行,然后根据;分解
再取出第二行,把第二行最后一个;去掉,并把这个字符串赋值给脚本中的一个变量namesrv
作者: The_X    时间: 2014-09-25 15:50
回复 9# ly5066113


    getline v  这个v是行号的意思吗?第一行就是getline 1 ?
作者: bulletmarquis    时间: 2014-09-25 15:50
回复 9# ly5066113


    为啥getline以后,$i取的还是当前行,没有取到下一行呢?
   一直以为getline以后,awk就开始读下一行去了。。。
作者: bulletmarquis    时间: 2014-09-25 15:51
回复 11# The_X


    getline v,是把下一行的$0取到变量v里面
作者: The_X    时间: 2014-09-25 15:55
回复 13# bulletmarquis


    帮忙看一下10楼吧,不会语法,
拜托~~~~
作者: bulletmarquis    时间: 2014-09-25 16:07
本帖最后由 bulletmarquis 于 2014-09-25 16:12 编辑

回复 14# The_X


首先取出第一行,然后根据;分解
再取出第二行,把第二行最后一个;去掉,并把这个字符串赋值给脚本中的一个变量namesrv


实在是看不懂你第一步和第二步有什么关联。。。
第一行根据分号分解以后做啥用?分解出来是放到一个数组里面还是做啥?

如果只是想取第二行,把最后的分号去掉再赋给变量,可以
  1. namesrv=$(sed -n 's/;$//;2p' file)
  2. echo $namesrv
  3. 10.10.10.30;10.10.10.31;10.10.10.32;10.10.10.33;10.10.10.60;10.10.10.61;10.10.10.62
复制代码
  1. $(sed -n 's/;$//;2p' file)也可以改成$(sed '2!d;s/;$//' file)
复制代码

作者: The_X    时间: 2014-09-25 16:18
回复 15# bulletmarquis


    没联系。。。。
突然想起来一个重要的问题,已经开辟新帖子。




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2