2011-08-03 138 views
7

我已经开始在我的配置文件中使用开始脚本来记录我通过shell执行的所有操作。PowerShell:读取PowerShell脚本日志

回头看看做了什么样的改变以及何时做出了改变。我也开始将它用作文档的第一步。我一直在评论在shell中完成的事情以供将来参考。

事实证明,棘手的是格式是文本文档的格式,并不像shell(主要是错误,详细和警告颜色)那么容易阅读。

我想知道是否有人使用这种方式的抄本功能,并有一个偏好查看器或脚本解析日志文件,以产生某种类型的文档?

编辑:我想知道,为什么这个问题一直往下投...

+0

另外一个,因为我现在有一个类似的问题也一样,我希望能够看到一个RTF或HTML文档作为输出的着色,而不是只是纯文本 - 审查 –

+0

时看到的事情有点清楚我相当肯定,有没有办法与成绩单完成此。既然我已经说过了,现在肯定会得到回复;) 着色只能由控制台(或IDE)处理。这就是为什么'Write-Host'包含'-ForegroundColor'和'-BackgroundColor',但'Write-Output'不能。 –

回答

4

我相信这将是非常困难的解析成绩单,建立一个准确格式的文档。但是,您可以使用控制台主机API来捕获(部分)屏幕缓冲区。

This Windows Powershell博客文章描述了这是如何工作的。

使用(修改后的)脚本(Get-ConsoleAsHtml.ps1)的一个简单方法是修改您的提示函数,以便缓冲区中尚未写入html转录文本的所有行都保存时间提示函数被调用。第一个代码块是修改脚本的内容,第二个代码块显示了如何在配置文件中使用此脚本。配置文件的

########################################################################################################### 
# Get-ConsoleAsHtml.ps1 
# 
# The script captures console screen buffer up to the current cursor position and returns it in HTML format. 
# (Jon Z: Added a startline parameter) 
# 
# Returns: UTF8-encoded string. 
# 
# Example: 
# 
# $htmlFileName = "$env:temp\ConsoleBuffer.html" 
# .\Get-ConsoleAsHtml 5 | out-file $htmlFileName -encoding UTF8 
# $null = [System.Diagnostics.Process]::Start("$htmlFileName") 
# 

param (
    $startline = 0 
) 

# Check the host name and exit if the host is not the Windows PowerShell console host. 
if ($host.Name -ne 'ConsoleHost') 
{ 
    write-host -ForegroundColor Red "This script runs only in the console host. You cannot run this script in $($host.Name)." 
    exit -1 
} 

# The Windows PowerShell console host redefines DarkYellow and DarkMagenta colors and uses them as defaults. 
# The redefined colors do not correspond to the color names used in HTML, so they need to be mapped to digital color codes. 
# 
function Normalize-HtmlColor ($color) 
{ 
    if ($color -eq "DarkYellow") { $color = "#eeedf0" } 
    if ($color -eq "DarkMagenta") { $color = "#012456" } 
    return $color 
} 

# Create an HTML span from text using the named console colors. 
# 
function Make-HtmlSpan ($text, $forecolor = "DarkYellow", $backcolor = "DarkMagenta") 
{ 
    $forecolor = Normalize-HtmlColor $forecolor 
    $backcolor = Normalize-HtmlColor $backcolor 

    # You can also add font-weight:bold tag here if you want a bold font in output. 
    return "<span style='font-family:Courier New;color:$forecolor;background:$backcolor'>$text</span>" 
} 

# Generate an HTML span and append it to HTML string builder 
# 
function Append-HtmlSpan 
{ 
    $spanText = $spanBuilder.ToString() 
    $spanHtml = Make-HtmlSpan $spanText $currentForegroundColor $currentBackgroundColor 
    $null = $htmlBuilder.Append($spanHtml) 
} 

# Append line break to HTML builder 
# 
function Append-HtmlBreak 
{ 
    $null = $htmlBuilder.Append("<br>") 
} 

# Initialize the HTML string builder. 
$htmlBuilder = new-object system.text.stringbuilder 
$null = $htmlBuilder.Append("<pre style='MARGIN: 0in 10pt 0in;line-height:normal';font-size:10pt>") 

# Grab the console screen buffer contents using the Host console API. 
$bufferWidth = $host.ui.rawui.BufferSize.Width 
$bufferHeight = $host.ui.rawui.CursorPosition.Y 
$rec = new-object System.Management.Automation.Host.Rectangle 0,0,($bufferWidth - 1),$bufferHeight 
$buffer = $host.ui.rawui.GetBufferContents($rec) 

# Iterate through the lines in the console buffer. 
for($i = $startline; $i -lt $bufferHeight; $i++) 
{ 
    $spanBuilder = new-object system.text.stringbuilder 

    # Track the colors to identify spans of text with the same formatting. 
    $currentForegroundColor = $buffer[$i, 0].Foregroundcolor 
    $currentBackgroundColor = $buffer[$i, 0].Backgroundcolor 

    for($j = 0; $j -lt $bufferWidth; $j++) 
    { 
    $cell = $buffer[$i,$j] 

    # If the colors change, generate an HTML span and append it to the HTML string builder. 
    if (($cell.ForegroundColor -ne $currentForegroundColor) -or ($cell.BackgroundColor -ne $currentBackgroundColor)) 
    { 
     Append-HtmlSpan 

     # Reset the span builder and colors. 
     $spanBuilder = new-object system.text.stringbuilder 
     $currentForegroundColor = $cell.Foregroundcolor 
     $currentBackgroundColor = $cell.Backgroundcolor 
    } 

    # Substitute characters which have special meaning in HTML. 
    switch ($cell.Character) 
    { 
     '>' { $htmlChar = '&gt;' } 
     '<' { $htmlChar = '&lt;' } 
     '&' { $htmlChar = '&amp;' } 
     default 
     { 
     $htmlChar = $cell.Character 
     } 
    } 

    $null = $spanBuilder.Append($htmlChar) 
    } 

    Append-HtmlSpan 
    Append-HtmlBreak 
} 

# Append HTML ending tag. 
$null = $htmlBuilder.Append("</pre>") 

return $htmlBuilder.ToString() 

例子:

############################################################################################################ 
# Microsoft.PowerShell_profile.ps1 
# 

$docpath = [environment]::GetFolderPath([environment+SpecialFolder]::MyDocuments) 
$transcript = "$($docpath)\PowerShell_transcript.$(get-date -f 'yyyyMMddHHmmss').html"; 
$global:lastloggedline = 0 
function prompt { 
&'D:\Scripts\Get-ConsoleAsHtml.ps1' $global:lastloggedline | out-file $transcript -append; 
$global:lastloggedline = $host.ui.rawui.cursorposition.Y 
"PS $pwd$('>' * ($nestedPromptLevel + 1)) " 
} 
+0

有趣的想法,我将尽快与它合作 – Matt

+0

谢谢!这工作完美! –