助听器分体式好不好好坏怎么分?

mcshell 的BLOG
用户名:mcshell
文章数:83
评论数:129
访问量:143556
注册日期:
阅读量:5863
阅读量:12276
阅读量:363558
阅读量:1059069
51CTO推荐博文
& 在生成环境中通常运维需要执行非常多的重复命令,一台可能还好 多台就杯具了。尤其有时候要批量去更新多台服务器的文件,或者是删除。
&& 一个好运维都是懒惰的,所以自己写了个perl脚本可以远程去执行shell命令,很灵活。2个配置文件,一个管理服务器信息,一个放所需要执行的命令。
#!/usr/bin/perl
use Net::SSH::E my @ssh_ my $ssh_txt='ip_list.txt'; my $command_txt='command_txt.txt'; open FH,$ssh_ &&&&&&&&while(&FH&){ &&&&&&&&@ssh_list= &&&&&&&&print "正在登陆".$ssh_list[0]."...\n"; &&&&&&&&&ssh_conn("$ssh_list[0]","$ssh_list[1]","$ssh_list[2]","$ssh_list[3]"); &&&&&&&&} &&&&&&&&close&&&&FH; sub&&&&ssh_conn(){ &&&&&&&&&&&&&&&&my($host,$port,$user,$pass) = @_; &&&&&&&&&&&&&&&&my $ssh = Net::SSH::Expect-&new( &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&host&&&&&&&&=&&&&&&&&&&&&&$host, &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&port&&&&&&&&=&&&&&&&&&&&&&$port, &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&user&&&&&&&&=&&&&&&&&&&&&&$user, &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&password&&&&&&&&&&&&&&&&=&$pass, &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&no_terminal&&&&&&&& =&0, &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&raw_pty =&1, &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&timeout =&&&&&&&&&&&&&3, &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&$ssh-&debug(0); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&$ssh-&run_ssh() or die "SSH process coundn't start:$!"; &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&$ssh-&waitfor( '\(yes\/no\)\?$', 1 ); #交互式修改密码,给予2秒的时间 &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&$ssh-&send("yes\n"); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&$ssh-&waitfor( 'password:\s*$/', 1); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&$ssh-&send("$ssh_list[3]"); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&$ssh-&send("su - root"); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&$ssh-&waitfor( 'password:\s*$/', 1); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&$ssh-&send("$ssh_list[4]"); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&#$ssh-&waitfor("#\s*",2); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&open F1,$command_ &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&while(&F1&){ &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&my @command=split/\n/,$_; &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&print "$command[0]--&&&&&"; &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&$ssh-&exec("$command[0]"); &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&print "$ssh_list[0]命令执行完毕\n"; &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&} &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&close F1; &&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&$ssh-&close();
下面是2个文件内容。
[root@nagios script]# cat ip_list.txt 192.168.2.101&&&&22&&&&mcshell&&&& psswd&&&&server1 192.168.2.102&&&&22&&&&mcshell&&&& psswd&&&&server2 192.168.2.103&&&&22&&&&mcshell&&&& psswd&&&&server3 [root@nagios script]# cat command_txt.txt touch /home/mcshell/file1 touch /home/mcshell/file2
执行结果:
650) this.width=650;" border="0" alt="" src="/attachment/739529.jpg" />
当然我这里为了测试方便,用了写的比较简单,大家也可以发挥想象,直接把复杂的shell或者perl密令直接放在command_txt.txt中。同样可以批量处理
&本文出自 “” 博客,请务必保留此出处
了这篇文章
类别:┆阅读(0)┆评论(0)
15:53:16 01:55:25 17:51:27 17:57:43 19:52:37 21:36:46 21:38:23 09:56:13& 看到有人在CU上问,perl脚本可不可以出现在Makefile中.其实只要了解makefile的规则,就会发现,不止是perl脚本,包括编译好的c (当然也可以是其它语言) 程序都可以出现在makefile中.一个简单的Makefile描述规则组成:TARGET... : PREREQUISITES...COMMANDtarget:规则的目标.prerequisites:规则的依赖。command:规则的命令行。是规则所要执行的动作(任意的shell命令或者是可在shell下执行的程序)。它限定了make执行这条规则时所需要的动作。 这里的command,就是要执行的命令了,command要满足两个条件:1. command 必须可执行2. command 必须能够被 shell 找到, (使用绝对路径, 或者在shell的搜索范围内)&一个简单的例子:$ more Makefile all:&&&&&&& ./test.pl$ more test.pl #!/usr/bin/perlprint &hello world\n&;$ ll test.pl-rwxrwxr-x& 1 user group 38& 8月 31 14:43 test.pl $ make all./test.plhello world &可以看到我们的 perl 脚本 test.pl 被执行了.&
引用地址:
Subscribe to feed
VectorBus:VectorBus:::::silentdai:yanwen249:::当前位置:&>&&>&
perl实例之读取文件内容时跳过第一行、读取多行
发布时间:编辑:
本文分享两段perl实例代码,学习下在读取文件内容时,如何跳过第一行与读取多行内容的方法,有需要的朋友参考学习下。
perl读取文件内容时跳过第一行。
复制代码 代码示例:
#!/bin/perl
open READ,&&&,&G:/project-xiaomai/yourfile.txt&;
readline READ;&&& # skip the first line
&while (&READ&)
  print& $_;&
close READ;
附,perl一次读取多行内容。
复制代码 代码示例:
#!/bin/perl
open (TEST, &$infile&)
while (&TEST&)
{ my $line_1=$_;
my $line_2=&TEST&;
my $line_3=&TEST&;
my $line_4=&TEST&;
与 perl实例之读取文件内容时跳过第一行、读取多行 有关的文章
本文标题:
本页链接:
12345678910
12345678910Perl的经典用法分享
字体:[ ] 类型:转载 时间:
Perl的经典用法分享,学习perl的朋友可以参考下
用Open() 函数打开文件
打开文件的常用方法是: 代码如下:open(FH, "& $filename")&&& or die "Couldn't open $filename for reading: $!";
open() 函数通常带有两个参数,第一个为文件句柄,用于指向打开的文件,第二个参数是文件名及模式(文件的打开模式)的混合体,如果文件被成功打开,open()函数返回true,否则为false。我们用“or”来测试该条件。上述代码中的模式由小于字符(&)来表示。如果文件不存在,open()将返回false。此时,你可以读文件句柄,但不可以写。大于字符表示写。如果文件不存在,就会被创建。如果文件存在,文件被清除,以前的数据将会丢失。你可以写入文件句柄,但不可以读入。 代码如下:& # 如果文件不存在,就创建它open(FH, "& $filename")&&& or die "Couldn't open $filename for writing: $!";
如果文件不存在,添加模式(用两个大于符号表示)可以用来创建新文件,如果文件存在,该模式并不会清除原来的数据。同“&”或“读”模式一样,你只能对文件句柄进行写操作。 (所以的写入内容都添加到文件尾)。企图进行读操作,会产生运行错误。
代码如下:open(FH, "&& $filename")&&& or die "Couldn't open $filename for appending: $!";
通过“+&”模式,你可以既可以读文件,又可以写文件。你可以通过tell() 函数在文件内部移动,通过seek()函数进行定位。如果文件不存在,就会被创建。如果文件已经存在,原来的数据不会被清除。如果你打算清除原来的文件内容,或者自己调用truncate() 函数,或者使用“+&”模式。
代码如下:open(FH, "+& $filename")&&& or die "Couldn't open $filename for reading and writing: $!";
注意“+&”和“+&”的区别,两者都可以可读可写。前者为非破坏性写,后者为破坏性写。错误错误是如何出现的?很多地方都会出现错误:如目录不存在,文件不可写入,你的程序丢失了文件句柄等等。你应该检查系统调用的结果 (如open() 和sysopen()),看看是否调用成功。为了帮助用户查错,通常使用“or die()”,你应记住这些用法。首先,应写出系统调用失败(“open”)的信息。其次,应写出文件名的信息,以便修正错误时更容易地定位。第三,要写出打开文件的方式, (“for writing,”“for appending”)。第四,输出操作系统的出错信息(包含在$!中)。这样,一旦出现文件不能打开的问题,使用你的程序的用户会大体上知道为什么不能打开。有时,我们把第一个和第三个合并在一起:or die "unable to append to $filename: $!";
如果在open() 和出错信息中都写了文件的全名,你会冒改变了open() 的风险,使得出错信息不合时宜或不正确。 代码如下:& # 下面会出现虚假的出错信息open(FH, "&/var/run/file.pid")&&& or die "Can't open /var/log/file.pod for writing : $!"; 用 Sysopen()进行更多的控制&为了更好的控制文件的打开方式,可以使用 sysopen() 函数:& 代码如下:use F& sysopen(FH, $filename, O_RDWR|O_CREAT, 0666)&&& or die "Can't open $filename for reading/writing/creating : $!"; 函数 sysopen() 带有四个参数,第一个是同open()函数类似的文件句柄参数,第二个参数是不带模式信息的文件名,第三个参数是模式参数,由Fcntl 模块提供的逻辑OR运算组合起来的常数构成,第四个参数(可选),为八进制属性值(0666表示数据文件, 0777表示程序)。如果文件可以被打开,sysopen() 返回true,如果打开失败,则返回false。不同于open()函数,sysopen()不提供模式说明的简写方式,而是把一些常数组合起来,而且,每个模式常数有唯一的含义,只有通过逻辑OR运算才能将它们组合起来,你可以设置多个行为的组合。O_RDONLYRead-only& O_WRONLY&&&& Write-only& O_RDWR Reading and writing& O_APPEND Writes go to the end of the file& O_TRUNC Truncate the file if it existed& O_CREAT Create the file if it didn't exist& O_EXCLError if the file already existed (used with O_CREAT)
当你需要小心行事的时候,就使用sysopen() 函数,例如,如果你打算添加内容到文件中,如果文件不存在,不创建新文件,你可以这样写:sysopen(LOG, "/var/log/myprog.log", O_APPEND, 0666)or die "Can't open /var/log/myprog.log for appending: $!";
读入单个记录有一个容易的方法读入filehandles:用 &FH& 操作符。在标量内容下,它返回文件中的下一个记录,或者返回未定义出错信息。我们可以使用它来把一行读入到一个变量中:$line = &FH&;& die "Unexpected end-of-file" unless defined $在循环语句中,我们可以这样写: 代码如下:& while (defined ($record = &FH&)) {&&&& # long-winded&&& # $record is set to each record in the file, one at a time& } 因为要大量进行这样的工作,通常再进行一下简化,把记录放到$_ 中,而不是$record中: 代码如下:while (&FH&) {# $_ 每次为文件中的一个记录& }& 在Perl 5.004_04中,我们可以这样做:&&&& while ($record = &FH&) {&&& # $record 每次为文件中的一个记录& } defined() 将自动加上,在Perl 5.004_04以前的版本中,该命令给出一个警示。要了解所用的Perl版本,可在命令行下打入:&perl -v一旦我们读出了一个记录,通常打算去掉记录分隔符,(缺省值为换行符字符):chomp($record);Perl 4.0版本仅有chop()操作,去掉串的最后一个字符, 不管该字符是什么。chomp() 没有这么大的破坏性,如果有行分隔符存在,它仅去掉行分隔符。如果你打算去掉行分隔符,就用chomp() 来代替chop()。读入多个记录如果你调用&FH&,返回文件中剩余的记录。如果你处于文件尾,则返回空表: 代码如下:@records = &FH&;& if (@records) {&&& print "There were ", scalar(@records), " records read. ";& }& 在下面的一步中,进行赋值和测试两项工作: 代码如下:if (@records = &FH&) {&&& print "There were ", scalar(@records), " records read. ";& }chomp() 也可适用对数组操作:& @records = &FH&;& chomp(@records);&对于任何表达式,都可以进行chomp操作,故你可以在下面的一步中这样写:&chomp(@records = &FH&);
什么是记录?记录的缺省定义为:“行”。记录的定义由$/ 变量控制的,该变量存放所输入的记录的分隔符,因为换行符字符(根据定义!)是用来分隔行的,故其缺省值为串“ ”。例如,你可以用任何你想要替换的符号来代替“ ”。& $/ = ";";& $record = &FH&;& # 读入下一个用分号分隔的记录$/可以取其它两个有趣的值:空串("") 和undef。读入段落$/ =""的写法是用来指示Perl读入段落的,段落是由两个或两个以上的换行符构成的文本块。这不同于设置为" ",后者仅读入由两行组成的文本块。在这种情况下,将出现这样一个问题:如果有连续的空行存在,例如“text ”,你既可以把它解释为一个段落 ("text"),也可以解释为两个段落 ("text", 后面跟两个换行符,以及一个空段落,后面跟两个空行。) 在读入文本时,第二个解释用途不大。如果你正在读的段落出现上述情况,你不必过滤出“空”段落。 代码如下:$/ = " ";& while (&FH&) {&&&&&&& # 跳过空段&&& # ...& } 你可以把 $/设置为undef,它用于读入后面跟着两个或多个换行符组成的段落:& undef $/;while (&FH&) {&&&&&& # ...& }
读入整个文件$/ 的其它有趣的值为undef。如果设置为该值,就将告诉Perl,读命令将把文件的剩余部分作为一个串返回: 代码如下:undef $/;& $file = &FH&; 因为改变了 $/的值,将会影响以后的每次读操作,而不仅是下一个读操作。通常,你需要将该操作限制在局部。通过下面的例子,可以把文件句柄的内容读入到一个串中: 代码如下:{&&& local $/ =&&& $file = &FH&;& } 记住:Perl变量可读入很长的串。尽管你的文件大小不可以超出你的虚拟内存容量的限度,你仍可以读入尽可能多的数据。用正则表达式对文件进行操作一旦你有个包含了整个串的变量,你可以使用正则表达式,对整个文件进行操作,而不是对文件中的某个块进行操作。有两个有用的正则表达式标记/s和/m。一般,Perl的正则表达式对行进行处理,你可以这样写: 代码如下:undef $/;& $line = &FH&;& if ($line =~ /(b.*grass)$/) {&&& print "found ";& } 如果把我们的文件填入如下内容:& browngrass& bluegrass则输出为:found bluegrass它没有找到“browngrass”,这是因为$ 仅在串尾寻找其匹配, (或者在串结束前的一行)。如果在包含很多行的串中,用"^" 和"$" 来匹配,, 我们可以使用 /m ("multiline") 选项:if ($line =~ /(b.*grass)$/m) {}现在程序会把如下的信息输出:& found browngrass类似地,句点可以匹配除了换行符之外的所有字符: 代码如下:while (&FH&) {&&& if (/19(.*)$/) {&&&&& if ( & 20) {&&&&& $year = 2000+;&&&&& } else {&&&&& $year = 1900+;&&&&& }&&& }& } 如果我们从文件中读入“1981”,$_ 将包含“1981 ”。正则表达式中的句点匹配“8”和“1”, 而不匹配“ ”。这里正需要这样做,因为换行符不是日期的组成部分。对于一个包含很多行的串,我们也许要提取其中的大的块,这些块可能会跨越行分隔符。在这种情况下,我们可以使用 /s 选项,并用句点来匹配除了换行符以外的所有字符。 代码如下:if (ms) {&&& print "Found bold text: ";& } 此处,我用了{}来表示正则表达式的起始和结束,而不用斜杠,所以,我就可以告诉 Perl我正在匹配,起始字符为"m",结束字符为"s"。你可以把/s 和/m 选项组合使用: 代码如下:if (m{^&FONT COLOR="red"&(.*?)&/FONT&}sm) {&&& # ...& } 总结有两种方法打开文件:open()函数的特点是快速简捷,而sysopen()函数功能强大而复杂。通过 &FH& 操作符,可以读入一个记录,$/ 变量可以让你控制记录是什么。如果你打算把很多行的内容读入到一个串中,不要使用忘记/s和/m 这两个正则表达式标记。
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具

我要回帖

更多关于 语言分辨助听器 的文章

 

随机推荐