不能不懂脚本 技术笔试面试

百度脚本笔试题两道

最近碰到两道脚本题:

1、写脚本实现,可以用shell、perl等。在目录/tmp下找到100个以abc开头的文件,然后把这些文件的第一行保存到文件new中。
2、写脚本实现,可以用shell、perl等。把文件b中有的,但是文件a中没有的所有行,保存为文件c,并统计c的行数。
解答思路:

1:觉得用shell更好一些,代码如下

#!/bin/sh
for filename in `find /tmp -type f -name "abc*"|head -n 100`
do
sed -n '1p' $filename>>new
done

注释:第一,用到了find命令,其中-type f表示选取普通文件,-name用于设定文件名;第二,head -n 100命令用于取出前100项。第三,sed -n ‘1p’用于取出文件的第一行内容。第四,>>new表示追加到文件new中。
2:第二个题目还是用perl更方便一些,代码如下:
[rocrocket@wupengchong shellstudy]$ cat roc.pl

 
#!/usr/bin/perl -w
open B,"c" or die "c error.($!)";
my $find=0;
my ($myb,$mya);
while(){
	$find=0;
	chomp($myb=$_);
	print "B ",$myb,"\n";
	open A,"){
		chomp($mya=$_);
		print "A ",$mya,"\n";
		if($mya=~/$myb/){
			$find=1;
			print "FIND!\n";
		}
	}
	if($find==0){
		print C $myb,"\n";
	}
}
close A;
close B;
close C;
$linenum=`cat c|wc -l`;
print "c line count:",$linenum;

第二题一直没有很好的思路,就只好用笨方法实现了。
看看哪位能有更好的方法和思路?希望能留言交流:D
当然shell、perl、python都欢迎!
over~

30条评论

  1. 晕,评论怎么把一部分给吃了。。。。实际是:head -n100 new 小于号和括号之间没空格

  2. [root@linux-node1 ~]# cat a.log
    a
    b
    c
    [root@linux-node1 ~]# cat b.log
    a
    b
    c
    d
    e
    f
    t
    [root@linux-node1 ~]# grep -vwf a.log b.log
    d
    e
    f
    t
    [root@linux-node1 ~]# grep -vwf a.log b.log | tee c.log |wc -l
    4

    最近一直在读博主的文章,写的通俗易懂,专业,系统。

  3. 1:
    awk ‘FNR==NR&&i++”new”}’ /tmp/abc*

    2:
    awk ‘{if(FNR==NR) a[$0]=1;else {for (i in a) if(i==$0) next;
    print $0>”c” }}’ a b

  4. 1.为什么用sed而不用head -n 1
    2.如果不考虑顺序,先sort再comm也行吧。考虑顺序可以再和b行比较一下。

  5. 1:

    dir ./test* | xargs tail -qn1 >t
    or:
    for i in `dir ./test*`; do tail -n1 $i > tt; done

    2:

    diff t1 t2 | grep “<" | sed 's/^ tt ; cat tt | wc -l

  6. [引用开始]
    第二题解法:

    1 sort a b | uniq -u | tee c | wc -l
    2 grep -vFf a b | tee c | wc -l
    [引用结束]

    方法1不正确。原题中”文件b中有的,但是文件a中没有的所有行”,而不是”文件b中有的但是文件a中没有的,或者,文件a中有的但是文件b中没有的”。

    方法2还差一步,grep时要指定-x参数,表示是整行匹配。

  7. 第二题解法:

    1 sort a b | uniq -u | tee c | wc -l
    2 grep -vFf a b | tee c | wc -l

    第一题这个比较短:
    find /tmp -type f -name “abc*” | head -n 100 | xargs head -q -n 1 >> new

  8. 第二题Ruby实现:

    File.open(ARGV[2]) do |f|
    f.write((File.readlines(ARGV[0]) – File.readlines(ARGV[1])).join(“\n”))
    end

  9. 第二题Ruby实现

    File.open(ARGV[2]) do |f|
    f.write((File.readlines(ARGV[0]) – File.readlines(ARGV[1])).join(“\n”))
    end

  10. 第二题 Ruby实现:

    #!/usr/bin/ruby

    File.open(ARGV[2]) do |f|
    f.write((File.readlines(ARGV[0]) – File.readlines(ARGV[1])).join(“\n”))
    end

  11. TMD又没有格式,凑合看看吧。
    用了2.6的with语法,简洁多了。2.5以下需要启用或者干脆自己close。
    其实核心就一句set1 – set2

  12. with open(“b”,”r”) as f:
    set1 = set(f.readlines ());
    with open(“a”,”r”) as f:
    set2 = set(f.readlines ());
    count = 0;
    with open(“c”, w) as f:
    for line in list(set1 – set2):
    f.write (line);
    count += 1;
    print count;

发表您的评论

请您放心,您的信息会被严格保密。必填项已标识 *