如何在NSIS中以静默模式将命令输出重定向到文件?

如何在NSIS中以静默模式将命令输出重定向到文件?,nsis,Nsis,在GUI模式下,CopyFiles、Delete等命令将其数据输出到GUI(可能正在使用DetailPrint),NSIS论坛上提供了这些命令,用于将该数据(在部分的末尾)复制到文件中 查询: 如果安装程序在静默模式下运行,如何将相同的数据(在非静默模式下定向到GUI)获取到文件中 在GUI模式下,由于我在的帮助下通过DetailPrint将自定义日志定向到日志文件,因此所有日志都按顺序接收。这里的问题是从自定义日志中删除换行符。可能是DetailPrint将其删除。我该如何避免这种情况 例如:

在GUI模式下,
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上看起来并不好,因为该标记将出现在界面上。