awk:awk和shell当中的很多命令不同,他的书写规则很大程度的类似于C语言的方式,所以对于C系列程序员来说还是很友好的。比如,在awk命令当中嵌套for循环,if elseif 判断式,都可以按照C语言的书写方式进行写入。
基本用法:
①按字符切割 awk –F”:” ‘{print $3 $6}’ a.txt 按照冒号切割第三列和第六列
②NR行号 awk ‘{if (NR >= 20 && NR<=30) print $1}’ a.txt 打印20-30行数据 NF列号
③BEGIN和END块 awk允许定义BEGIN和END块,在该命令执行之前和执行之后执行。awk ‘{if (NR >= 20 && NR <= 30) print $1} BEGIN{print “-----“} END{print “------“}’ a.txt 在执行主体命令之前先输出“--------”执行完该主体之后输出“---------”。 查看某个文件夹下文件字节数ll |awk 'BEGIN {size=0;} {size=size+$5;} END{print "[end]size is ",size}'
④awk正则表达式
lambda表达式:[capture](parameters) mutable ->return-type{statement}
1.[capture]:捕捉列表。捕捉列表总是出现在Lambda函数的开始处。实际上,[]是Lambda引出符。编译器根据该引出符判断接下来的代码是否是Lambda函数。捕捉列表能够捕捉上下文中的变量以供Lambda函数使用;
2.(parameters):参数列表。与普通函数的参数列表一致。如果不需要参数传递,则可以连同括号“()”一起省略;
3.mutable:mutable修饰符。默认情况下,Lambda函数总是一个const函数,mutable可以取消其常量性。在使用该修饰符时,参数列表不可省略(即使参数为空);
4.->return-type:返回类型。用追踪返回类型形式声明函数的返回类型。我们可以在不需要返回值的时候也可以连同符号”->”一起省略。此外,在返回类型明确的情况下,也可以省略该部分,让编译器对返回类型进行推导;
5.{statement}:函数体。内容与普通函数一样,不过除了可以使用参数之外,还可以使用所有捕获的变量。
代码:
enum type{
add = 0,
sub,
mul,
del};
int main(){
auto func = [](int a, int b, type i)->int{
switch (i)
{
case 0:
return a + b;
case 1:
return a - b;
case 2:
return a*b;
case 3:
return a / b;
}
};
cout << func(10, 5, add) << endl;
multimap遍历所有的相同值:
multimap可以存放相同键值的数据,取出方式:
multimap<int, int> mymap;
mymap.insert(make_pair(1, 1));
mymap.insert(make_pair(1, 2));
mymap.insert(make_pair(1, 3));
mymap.insert(make_pair(2, 5));
mymap.insert(make_pair(3, 9));
multimap<int, int>::size_type cnt = mymap.count(1);
multimap<int, int>::iterator it = mymap.find(1);
if (it != mymap.end())
for (; cnt > 0; cnt--,it++)
cout << it->first<<"----"<<it->second << endl;
return 0;