如何在NSIS中以静默模式将命令输出重定向到文件?
在GUI模式下,如何在NSIS中以静默模式将命令输出重定向到文件?,nsis,Nsis,在GUI模式下,CopyFiles、Delete等命令将其数据输出到GUI(可能正在使用DetailPrint),NSIS论坛上提供了这些命令,用于将该数据(在部分的末尾)复制到文件中 查询: 如果安装程序在静默模式下运行,如何将相同的数据(在非静默模式下定向到GUI)获取到文件中 在GUI模式下,由于我在的帮助下通过DetailPrint将自定义日志定向到日志文件,因此所有日志都按顺序接收。这里的问题是从自定义日志中删除换行符。可能是DetailPrint将其删除。我该如何避免这种情况 例如:
CopyFiles
、Delete
等命令将其数据输出到GUI(可能正在使用DetailPrint
),NSIS论坛上提供了这些命令,用于将该数据(在部分的末尾)复制到文件中
查询:
如果安装程序在静默模式下运行,如何将相同的数据(在非静默模式下定向到GUI)获取到文件中
在GUI模式下,由于我在的帮助下通过DetailPrint
将自定义日志定向到日志文件,因此所有日志都按顺序接收。这里的问题是从自定义日志中删除换行符。可能是DetailPrint
将其删除。我该如何避免这种情况
例如:
DetailPrint "This is a custom log1"
DetailPrint "$\r$\nThis is a custom log2"
/*
Dumped these logs using function mentioned above
Output in logs(with no line breaks):
This is a custom log1
This is a custom log2
Required output:
This is a custom log1
This is a custom log2
*/
您的第二个问题已解决
!include "MUI2.nsh"
section
StrCpy $0 "$EXEDIR\install.log"
Push $0
DetailPrint "This is a custom log1"
DetailPrint "This is a custom log2"
Call DumpLog
sectionend
;!define LVM_GETITEMCOUNT 0x1004
!define LVM_GETITEMTEXT 0x102D
Function DumpLog
Exch $5
Push $0
Push $1
Push $2
Push $3
Push $4
Push $6
FindWindow $0 "#32770" "" $HWNDPARENT
GetDlgItem $0 $0 1016
StrCmp $0 0 exit
FileOpen $5 $5 "w"
StrCmp $5 "" exit
SendMessage $0 ${LVM_GETITEMCOUNT} 0 0 $6
System::Alloc ${NSIS_MAX_STRLEN}
Pop $3
StrCpy $2 0
System::Call "*(i, i, i, i, i, i, i, i, i) i \
(0, 0, 0, 0, 0, r3, ${NSIS_MAX_STRLEN}) .r1"
loop: StrCmp $2 $6 done
System::Call "User32::SendMessageA(i, i, i, i) i \
($0, ${LVM_GETITEMTEXT}, $2, r1)"
System::Call "*$3(&t${NSIS_MAX_STRLEN} .r4)"
FileWrite $5 "$4$\r$\n"
FileWrite $5 "$\r$\n"
IntOp $2 $2 + 1
Goto loop
done:
FileClose $5
System::Free $1
System::Free $3
exit:
Pop $6
Pop $4
Pop $3
Pop $2
Pop $1
Pop $0
Exch $5
FunctionEnd
您的示例代码对我很有用。它根据您的要求给我输出。
不要将“$\r$\n”
放在详细打印中。像我一样,在DumpLog函数中添加FileWrite$5“$\r$\n”
。这样,您就不必在每次详细打印中都输入$\r$\n
。请输入您的相关代码。。所以我们可以就此提出建议。我已经提到了函数的链接(转储日志)。如果你说的是第二个查询,那么我已经用一个例子更新了这篇文章。让我检查一下我的代码,看看有什么问题。根据你修改后的答案,在每个日志之后都会添加换行符。但这不是要求。只有少数日志(不是每个日志)会有换行。在这里,目的是将特定模块的日志分组在一起,添加换行符,然后添加下一个模块的日志。这是必需的,以便日志看起来不凌乱。可能是因为如果没有直接的解决方案,那么解决方法可能是我们可以在日志中添加一个换行标记,然后在函数DumpLog
中将其替换为$\r$\n
。但这在GUI上看起来并不好,因为该标记将出现在界面上。