{"id":2184,"date":"2016-07-17T13:55:49","date_gmt":"2016-07-17T04:55:49","guid":{"rendered":"http:\/\/1bed.allright.life\/?p=2184"},"modified":"2020-04-18T21:25:35","modified_gmt":"2020-04-18T12:25:35","slug":"post-2184","status":"publish","type":"post","link":"https:\/\/1bed.allright.life\/?p=2184","title":{"rendered":"PowerShell \u3067\u306e\u30ed\u30b0\u51fa\u529b\u3092\u9811\u5f35\u3063\u3066\u3044\u305f\u3089 logger \u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u304c\u3067\u304d\u305f"},"content":{"rendered":"<h2>\u7d4c\u7def<\/h2>\n<p>\u3053\u306e 2 \u30f6\u6708\u3001\u4ed5\u4e8b\u3067\u7d50\u69cb PowerShell \u3067\u30b9\u30af\u30ea\u30d7\u30c8\u3092\u4f5c\u3063\u3066\u3044\u308b\u3002<br \/>\n\u6bce\u56de\u30c6\u30ad\u30c8\u30fc\u306b\u30ed\u30b0\u51fa\u3057\u3066\u3044\u305f\u3089\u30ed\u30b0\u306e\u4f7f\u3044\u52dd\u624b\u304c\u60aa\u3044\u306e\u3067\u3001\u30ed\u30b0\u51fa\u529b\u3092\u30e6\u30fc\u30b6\u30fc\u5b9a\u7fa9\u95a2\u6570\u3068\u3057\u3066\u4f5c\u3063\u305f\u304c\u3001\u72b6\u614b\u3092\u6301\u3066\u306a\u3044\u306e\u3067\u306a\u3093\u304b\u30c0\u30b5\u304b\u3063\u305f\u3002<\/p>\n<pre><code class=\"language-powershell\"># \u7406\u60f3\n$logger.info(&quot;log message&quot;)\n$logger.error(&quot;log message&quot;)\n\n# \u73fe\u5b9f\nPut-Log -Message &quot;log message&quot; -File &quot;C:\\hoge.txt&quot; -Info \nPut-Log -Message &quot;log message&quot; -File &quot;C:\\hoge.txt&quot; -ERROR <\/code><\/pre>\n<p>\u30ed\u30b0\u30d5\u30a1\u30a4\u30eb\u306e\u30d1\u30b9\u3092\u30b0\u30ed\u30fc\u30d0\u30eb\u5909\u6570\u306b\u3059\u308b\u3068\u304b\u8272\u3005\u8003\u3048\u3066\u3044\u305f\u3051\u3069\u3001\u3075\u3068\u3001\u300c\u30b9\u30af\u30ea\u30d7\u30c8\u30d6\u30ed\u30c3\u30af\u3092\u4f7f\u3063\u305f\u3089\u306a\u3093\u304b\u4e0a\u624b\u304f\u3044\u304f\u3093\u3058\u3083\u306d\uff1f\u300d\u3068\u601d\u3044\u3001\u8eca\u8f2a\u306e\u518d\u767a\u660e\u306b\u306a\u308b\u306e\u3060\u308d\u3046\u304c\u81ea\u4f5c\u3057\u3066\u307f\u305f\u3002\u5f8c\u6094\u306f\u3057\u3066\u3044\u306a\u3044\u3002<\/p>\n<p>Claas \u3092\u4f7f\u3046\u3068\u3044\u3046\u4e8b\u3082\u4e00\u77ac\u982d\u3092\u904e\u304e\u3063\u305f\u304c\u3001PowerShell 5.0 \u3092\u4ed5\u4e8b\u3067\u4f7f\u3046\u306e\u306f\u307e\u3060\u5148\u306b\u306a\u308a\u305d\u3046\u306a\u306e\u3067\u3059\u3050\u306b\u4f7f\u3048\u308b\u307b\u3046\u3092\u9078\u3093\u3060\u3002<\/p>\n<h2>\u7d50\u679c(\u4f7f\u7528\u65b9\u6cd5)<\/h2>\n<p>\u30ed\u30b0\u3092\u753b\u9762\u51fa\u529b\u3059\u308b(Write-Host \u4f7f\u7528)<\/p>\n<pre><code class=\"language-powershell\"># \u30ed\u30ac\u30fc\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u53d6\u5f97\n$logger = Get-Logger\n\n# \u30ed\u30b0\u30ec\u30d9\u30eb Info \u3067\u30ed\u30b0\u3092\u51fa\u529b\n$logger.info.Invoke(&quot;Message&quot;)\n\n# \u30ed\u30b0\u30ec\u30d9\u30eb Warninng \u3067\u30ed\u30b0\u3092\u51fa\u529b\n$logger.warn.Invoke(&quot;Message&quot;)\n\n# \u30ed\u30b0\u30ec\u30d9\u30eb Error \u3067\u30ed\u30b0\u3092\u51fa\u529b\n$logger.error.Invoke(&quot;Message&quot;)<\/code><\/pre>\n<p>\u753b\u9762\u51fa\u529b\u3068\u540c\u6642\u306b\u30ed\u30b0\u30d5\u30a1\u30a4\u30eb\u3092\u51fa\u529b<\/p>\n<pre><code class=\"language-powershell\"># \u30ed\u30b0\u30d5\u30a1\u30a4\u30eb\u3092\u30bb\u30c3\u30c8\u3057\u3066\u30ed\u30ac\u30fc\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3092\u53d6\u5f97\n$logger = Get-Logger -Logfile &quot;C:\\hoge\\hoge.log&quot;\n\n# \u30ed\u30b0\u30ec\u30d9\u30eb Info \u3067\u30ed\u30b0\u3092\u51fa\u529b\n$logger.info.Invoke(&quot;Message&quot;)<\/code><\/pre>\n<p>\u753b\u9762\u51fa\u529b\u306f\u884c\u308f\u305a\u3001\u30ed\u30b0\u30d5\u30a1\u30a4\u30eb\u306e\u307f\u51fa\u529b<\/p>\n<pre><code class=\"language-powershell\"># \u30ed\u30b0\u30d5\u30a1\u30a4\u30eb\u3092\u30bb\u30c3\u30c8\u3057\u3001\u30c7\u30a3\u30b9\u30d7\u30ec\u30a4\u51fa\u529b\u3092\u6b62\u3081\u308b\u30b9\u30a4\u30c3\u30c1\u3092\u4ed8\u3051\u3066\u30ed\u30ac\u30fc\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3092\u53d6\u5f97\n$logger = Get-Logger -Logfile &quot;C:\\hoge\\hoge.log&quot; -NoDisplay\n\n# \u30ed\u30b0\u30ec\u30d9\u30eb\u3092 Info  \u3067\u30ed\u30b0\u3092\u51fa\u529b\n$logger.info.Invoke(&quot;Message&quot;)<\/code><\/pre>\n<h2>\u30b3\u30fc\u30c9<\/h2>\n<pre><code class=\"language-powershell\">function Global:Get-Logger{\n    Param(\n        [CmdletBinding()]\n        [Parameter()]\n        [String]$Delimiter = &quot; &quot;,\n        [Parameter()]\n        [String]$Logfile,\n        [Parameter()]\n        [String]$Encoding = &quot;Default&quot;,\n        [Parameter()]\n        [Switch]$NoDisplay\n    )\n    if (!(Test-Path -LiteralPath (Split-Path $Logfile -parent) -PathType container)) {\n        New-Item $Logfile -type file -Force\n    }\n    $logger = @{}\n    $logger.Set_Item(&#039;info&#039;, (Put-Log -Delimiter $Delimiter -Logfile $logfile -Encoding $Encoding -NoDisplay $NoDisplay -Info))\n    $logger.Set_Item(&#039;warn&#039;, (Put-Log -Delimiter $Delimiter -Logfile $logfile -Encoding $Encoding -NoDisplay $NoDisplay -Warn))\n    $logger.Set_Item(&#039;error&#039;, (Put-Log -Delimiter $Delimiter -Logfile $logfile -Encoding $Encoding -NoDisplay $NoDisplay -Err))\n    return $logger\n}\n\nfunction Global:Put-Log\n{\n    Param(\n        [CmdletBinding()]\n        [Parameter()]\n        [String]$Delimiter = &quot; &quot;,\n        [Parameter()]\n        [String]$Logfile,\n        [Parameter()]\n        [String]$Encoding,\n        [Parameter()]\n        [bool]$NoDisplay,\n        [Parameter()]\n        [Switch]$Info,\n        [Parameter()]\n        [Switch]$Warn,\n        [Parameter()]\n        [Switch]$Err\n    )\n    return {\n        param([String]$msg = &quot;&quot;)\n\n        # Initialize variables\n        $logparam = @(&quot;White&quot;, &quot;INFO&quot;)\n        if ($Warn)  { $logparam = @(&quot;Yellow&quot;, &quot;WARN&quot;) }\n        if ($Err) { $logparam = @(&quot;Red&quot;, &quot;ERROR&quot;) }\n        $txt = &quot;[$(Get-Date -Format &quot;yyyy\/MM\/dd HH:mm:ss&quot;)]${Delimiter}{0}${Delimiter}{1}&quot; -f $logparam[1], $msg\n\n        # Output Display\n        if(!$NoDisplay) {\n            Write-Host -ForegroundColor $logparam[0] $txt\n        }\n        # Output logfile\n        if($Logfile) {\n            Write-Output $txt | Out-File -FilePath $Logfile -Append -Encoding $Encoding\n        }\n    }.GetNewClosure()\n}<\/code><\/pre>\n<p>\u4e0a\u8a18\u306e\u30b3\u30fc\u30c9\u306f\u30b3\u30e1\u30f3\u30c8\u3092\u524a\u3063\u3066\u3044\u308b\u3002\u6700\u65b0\u306e\u30b3\u30fc\u30c9\u306f <a href=\"https:\/\/github.com\/miyamiya\/mypss\">GitHub<\/a> \u53c2\u7167\u3002<\/p>\n<h2>\u8003\u5bdf<\/h2>\n<p>\u7d50\u69cb\u7406\u60f3\u306b\u8fd1\u3044\u7d50\u679c\u306b\u306a\u3063\u305f\u3057\u3001PowerShell \u89e6\u308a\u59cb\u3081\u3066 2 \u30f6\u6708\u3001PowerShell \u3068\u5c11\u3057\u4ef2\u826f\u304f\u306a\u308c\u305f\u6c17\u304c\u3059\u308b\u3002<\/p>\n<p><a href=\"http:\/\/1bed.allright.life\/?p=2125\">PowerShell \u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u6307\u5b9a\u3057\u3066<\/a>\u30012.0 \u3067\u3082\u52d5\u3044\u305f\u306e\u3067\u3001\u5272\u3068\u4f7f\u3048\u308b\u6c17\u304c\u3057\u3066\u3044\u308b\u306e\u3067\u3001\u307e\u305a\u306f\u4ed5\u4e8b\u3067\u4f7f\u3063\u3066\u307f\u3088\u3046\u304b\u306a\u3002<\/p>\n<h2>\u53c2\u8003<\/h2>\n<ul>\n<li><a href=\"http:\/\/mtgpowershell.blogspot.jp\/2011\/11\/blog-post_27.html\">\u25c6\u30b9\u30af\u30ea\u30d7\u30c8\u30d6\u30ed\u30c3\u30af\u3092\u4f7f\u3046<\/a><\/li>\n<li><a href=\"https:\/\/technet.microsoft.com\/en-us\/library\/hh847893.aspx\">about_Script_Blocks<\/a><\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>\u7d4c\u7def \u3053\u306e 2 \u30f6\u6708\u3001\u4ed5\u4e8b\u3067\u7d50\u69cb PowerShell \u3067\u30b9\u30af\u30ea\u30d7\u30c8\u3092\u4f5c\u3063\u3066\u3044\u308b\u3002 \u6bce\u56de\u30c6\u30ad\u30c8\u30fc\u306b\u30ed\u30b0\u51fa\u3057\u3066\u3044\u305f\u3089\u30ed\u30b0\u306e\u4f7f\u3044\u52dd\u624b\u304c\u60aa\u3044\u306e\u3067\u3001\u30ed\u30b0\u51fa\u529b\u3092\u30e6\u30fc\u30b6\u30fc\u5b9a\u7fa9\u95a2\u6570\u3068\u3057\u3066\u4f5c\u3063\u305f\u304c\u3001\u72b6\u614b\u3092\u6301\u3066\u306a\u3044\u306e\u3067\u306a\u3093\u304b\u30c0\u30b5\u304b\u3063\u305f\u3002  [&hellip;]<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[6],"tags":[62],"class_list":["post-2184","post","type-post","status-publish","format-standard","hentry","category-program","tag-powershell"],"_links":{"self":[{"href":"https:\/\/1bed.allright.life\/index.php?rest_route=\/wp\/v2\/posts\/2184","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/1bed.allright.life\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/1bed.allright.life\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/1bed.allright.life\/index.php?rest_route=\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/1bed.allright.life\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=2184"}],"version-history":[{"count":14,"href":"https:\/\/1bed.allright.life\/index.php?rest_route=\/wp\/v2\/posts\/2184\/revisions"}],"predecessor-version":[{"id":3152,"href":"https:\/\/1bed.allright.life\/index.php?rest_route=\/wp\/v2\/posts\/2184\/revisions\/3152"}],"wp:attachment":[{"href":"https:\/\/1bed.allright.life\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2184"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/1bed.allright.life\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=2184"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/1bed.allright.life\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=2184"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}