
勉强给搞了一个:
#!/bin/bash
TIME=`grep -m1 'TIME' testxml | sed -r -n 's/TIME=([^:]:[^:]):$/\1/p'`
awk -v RS='</类型>' -v t=$TIME '{print t" " gensub(/^城市\[([^]])\](PM25)[^0-9]([0-9]+)[^0-9]([0-9]+)$/,"\\1 \\2 \\3 \\4","g")}' testxml
return=`linux命令` 会将linux命令的结果赋值给return
return=$(linux命令)也是将linux命令的结果赋值给return的一种方式
灵活使用能解决很多问题
一般日志这种都应该是一行的,你把终端屏幕缩小,并且全屏,然后在看一下。
读取文件的每一行内容并输出
写法一:
#!/bin/bash
while read line
do
echo $line
done < file(待读取的文件)
写法二:
#!/binbash
cat file(待读取的文件) | while read line
do
echo $line
done
写法三:
for line in `cat file(待读取的文件)`
do
echo $line
done
调用系统函数popen,利用管道实现输出的传送即可。
popen() 函数通过创建一个管道,调用 fork 产生一个子进程,执行一个 shell 以运行命令来开启一个进程。这个进程必须由 pclose() 函数关闭,而不是 fclose() 函数。pclose() 函数关闭标准 I/O 流,等待命令执行结束,然后返回 shell 的终止状态。如果 shell 不能被执行,则 pclose() 返回的终止状态与 shell 已执行 exit 一样。
type 参数只能是读或者写中的一种,得到的返回值(标准 I/O 流)也具有和 type 相应的只读或只写类型。如果 type 是 "r" 则文件指针连接到 command 的标准输出;如果 type 是 "w" 则文件指针连接到 command 的标准输入。
command 参数是一个指向以 NULL 结束的 shell 命令字符串的指针。这行命令将被传到 bin/sh 并使用-c 标志,shell 将执行这个命令。
popen 的返回值是个标准 I/O 流,必须由 pclose 来终止。前面提到这个流是单向的。所以向这个流写内容相当于写入该命令的标准输入;命令的标准输出和调用 popen 的进程相同。与之相反的,从流中读数据相当于读取命令的标准输出;命令的标准输入和调用 popen 的进程相同。
例程如下:
#include <cstdio>#include <unistdh>
#include <cstring>
#include <cstdlib>
int main()
{
FILE read_fp;
char buffer[BUFSIZ + 1];
int chars_read;
memset(buffer, '\0', sizeof(buffer));
read_fp = popen ("uname -a", "r");
if (read_fp != NULL)
{
chars_read = fread(buffer, sizeof(char), BUFSIZ, read_fp);
if (chars_read > 0)
{
printf("Output was: \n %s \n", buffer);
}
pclose(read_fp);
exit(EXIT_SUCCESS);
}
exit(EXIT_FAILURE);
}
运行结果如下:
以上就是关于用shell处理xml文件,并输出内容全部的内容,包括:用shell处理xml文件,并输出内容、shell 如何获取一条命令的输出结果、shell如何把多行内容输出到一个文件等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)