PowerShell脚本运行慢怎么办?影响到正常企业流程正常运转怎么办?本文利用例子和数据给你们带来让PowerShell运行更快的五个经常使用方法。本人拙见,但愿可以给你们带来一点启发~html
若是要查询事件ID为16的系统日志,通常人会这样写PowerShell脚本:程序员
而大牛们会这样写代码:正则表达式
哪个运行更快呢?来看效率对比结果:数据库
显然,第二种方法要快上数倍以上。第一种方法须要查询遍历整个事件日志后再在内存中过滤结果,而第二种方法直接使用命令自带的参数过滤结果后输出。数组
使用某一个PowerShell命令前,要多多查询命令帮助文档,若是有过滤类型的参数,强烈推荐使用它来代替常规管道符过滤方法。服务器
刚开始看Help的时候可能会显得枯燥乏味,当你看懂后就会更好地提升脚本的效率,写出更棒的脚本。学习
若是要从数据库中获取Type为0而且大小大于100000的文档对象ID,有些人可能会这样写代码:3d
还有一些人会这样写代码:日志
哪种运行更快呢?来看效率对比结果:htm
显然第二种要快上几倍。复杂的TSQL查询语句使得返回的对象要少一些,耗时长的语句循环次数减小不少。
尽可能减小客户端与服务器端交流的次数,复杂而精确的查询语句可使服务器返回尽可能少的结果,该方法不止适用于数据库查询状况,也用于AD查询,Office 365查询等。
若是要执行相似循环遍历给一个文件末尾添加内容的操做,有些人可能会使用一些已有的PowerShell操做API,好比Add-Content,Out-File -Append和Export-CSV Append等。以下:
对于很小的文件,这些方法比较适用,若是是数以万计的文件循环,则会大大的影响效率。
这里推荐使用.NET对象来代替已有PowerShell API,以下:
效率对好比下:
显然,第二种要比第一种方法快上数倍以上,缘由是因为Add-Content操做,每一次调用都须要这几步骤——打开文件、滚到最后、添加内容、关闭文件,因此大量执行才会很慢。
PowerShell一些现成的API使用起来很方便,可是也有本身的弊端,建议使用以前必定要细读帮助文档,了解具体过程,才能最佳的使用。
在给一个数组添加对象的时候,有些人会像下面的方法写,以及效率对好比下:
能够看出,第二种方法效率高的不是一星半点,并且数组越大,差距越明显。
缘由是:在第一种方法执行过程当中,.Net会复制整个数组到内存中,添加对象而且删除原来的旧数组。既耗时又耗费空间。
正则表达式是一个老生常谈的技术,我相信没有一个程序员不知道的。在PowerShell中正则表达式也具备高效的解析字符串的功能。请看以下例子:
我想把”TestDomain\TestUser”经过分析字符串的方法,取出Domain和User。
能够看到第二种正则表达式的方法是最高效的。
正则表达式是每个程序员必备的知识,应用巨普遍。在PowerShell中检索字符串匹配还具备很高的效率,建议你们必定要吃透用透。
[原创文章,转载请注明出处,仅供学习研究之用,若有错误请留言,如以为不错请推荐,谢谢支持]
[原文:http://www.cnblogs.com/lavender000/p/7216477.html ,来自永远薰薰]