PowerShell tee对象在db2命令中使用时,在输出中生成空行



当我使用powershell tee-object cmdlet将输出保存到文件中时,在每个实际行之间都会创建空行。在屏幕输出和重定向文件中,输出都会加倍且丑陋。

常规命令和输出:

# db2 connect to sample
Database Connection Information
Database server        = DB2/NT64 11.5.0.0
SQL authorization ID   = SAMUEL
Local database alias   = SAMPLE

但是,当你对它使用Tee对象时……会发生以下情况:

# db2 connect to sample |  Tee-Object test.out

Database Connection Information

Database server        = DB2/NT64 11.5.0.0
SQL authorization ID   = SAMUEL
Local database alias   = SAMPLE

在两个屏幕输出中,也在生成的文件中一个井:

# type test.out

Database Connection Information

Database server        = DB2/NT64 11.5.0.0
SQL authorization ID   = SAMUEL
Local database alias   = SAMPLE

---编辑---@js2010,下面是整个十六进制格式,以便更好地阅读。。无法将其正确粘贴到评论中。

# format-hex test.out

Path: E:PowerShell_Testsdb2montest.out
00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
00000000   FF FE 0D 00 0A 00 0D 00 0A 00 20 00 20 00 20 00  .þ........ . . .
00000010   44 00 61 00 74 00 61 00 62 00 61 00 73 00 65 00  D.a.t.a.b.a.s.e.
00000020   20 00 43 00 6F 00 6E 00 6E 00 65 00 63 00 74 00   .C.o.n.n.e.c.t.
00000030   69 00 6F 00 6E 00 20 00 49 00 6E 00 66 00 6F 00  i.o.n. .I.n.f.o.
00000040   72 00 6D 00 61 00 74 00 69 00 6F 00 6E 00 0D 00  r.m.a.t.i.o.n...
00000050   0A 00 0D 00 0A 00 0D 00 0A 00 0D 00 0A 00 20 00  .............. .
00000060   44 00 61 00 74 00 61 00 62 00 61 00 73 00 65 00  D.a.t.a.b.a.s.e.
00000070   20 00 73 00 65 00 72 00 76 00 65 00 72 00 20 00   .s.e.r.v.e.r. .
00000080   20 00 20 00 20 00 20 00 20 00 20 00 20 00 3D 00   . . . . . . .=.
00000090   20 00 44 00 42 00 32 00 2F 00 4E 00 54 00 36 00   .D.B.2./.N.T.6.
000000A0   34 00 20 00 31 00 31 00 2E 00 35 00 2E 00 30 00  4. .1.1...5...0.
000000B0   2E 00 30 00 0D 00 0A 00 0D 00 0A 00 20 00 53 00  ..0......... .S.
000000C0   51 00 4C 00 20 00 61 00 75 00 74 00 68 00 6F 00  Q.L. .a.u.t.h.o.
000000D0   72 00 69 00 7A 00 61 00 74 00 69 00 6F 00 6E 00  r.i.z.a.t.i.o.n.
000000E0   20 00 49 00 44 00 20 00 20 00 20 00 3D 00 20 00   .I.D. . . .=. .
000000F0   53 00 41 00 4D 00 55 00 45 00 4C 00 0D 00 0A 00  S.A.M.U.E.L.....
00000100   0D 00 0A 00 20 00 4C 00 6F 00 63 00 61 00 6C 00  .... .L.o.c.a.l.
00000110   20 00 64 00 61 00 74 00 61 00 62 00 61 00 73 00   .d.a.t.a.b.a.s.
00000120   65 00 20 00 61 00 6C 00 69 00 61 00 73 00 20 00  e. .a.l.i.a.s. .
00000130   20 00 20 00 3D 00 20 00 53 00 41 00 4D 00 50 00   . .=. .S.A.M.P.
00000140   4C 00 45 00 0D 00 0A 00 0D 00 0A 00 0D 00 0A 00  L.E.............
00000150   0D 00 0A 00                                      ....

此外,您的第二次测试表明,问题不是关于使用tee-object cmdlet,而是实际上,只是通过管道传输输出导致了它…

另一个信息,如果我从常规的windows cmd窗口执行重定向到文件,问题不会发生,

从cmd窗口:

E:PowerShell_Testsdb2mon>db2 connect to sample > cmd.out
E:PowerShell_Testsdb2mon>type cmd.out
Database Connection Information
Database server        = DB2/NT64 11.5.0.0
SQL authorization ID   = SAMUEL
Local database alias   = SAMPLE

但是,从powershell会话执行相同的重定向,再次创建了双线:

# db2 connect to sample > pwsh.out
PS [Samuel]E:PowerShell_Testsdb2mon
# Get-Content pwsh.out

Database Connection Information

Database server        = DB2/NT64 11.5.0.0
SQL authorization ID   = SAMUEL
Local database alias   = SAMPLE

---结束编辑---

---编辑2---@js2010

# db2 connect to sample | format-hex

00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
00000000   20 20 20 44 61 74 61 62 61 73 65 20 43 6F 6E 6E     Database Conn
00000010   65 63 74 69 6F 6E 20 49 6E 66 6F 72 6D 61 74 69  ection Informati
00000020   6F 6E                                            on

00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
00000000   20 44 61 74 61 62 61 73 65 20 73 65 72 76 65 72   Database server
00000010   20 20 20 20 20 20 20 20 3D 20 44 42 32 2F 4E 54          = DB2/NT
00000020   36 34 20 31 31 2E 35 2E 30 2E 30                 64 11.5.0.0

00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
00000000   20 53 51 4C 20 61 75 74 68 6F 72 69 7A 61 74 69   SQL authorizati
00000010   6F 6E 20 49 44 20 20 20 3D 20 53 41 4D 55 45 4C  on ID   = SAMUEL

00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
00000000   20 4C 6F 63 61 6C 20 64 61 74 61 62 61 73 65 20   Local database
00000010   61 6C 69 61 73 20 20 20 3D 20 53 41 4D 50 4C 45  alias   = SAMPLE

---结束编辑2-

有人知道发生了什么吗?我该如何"修复"它?

感谢

正如您的Format-Hex输出所暗示的,db2-奇怪的是-使用CRCRLF(PowerShell术语中的"`r`r`n"(而不是通常的CRLF序列("`r`n"(作为换行符(以分隔其输出行(-这是它与sfc.exe共享的行为。

当您打印到显示时,这种异常不会出现,但当您捕获或重定向输出时会出现,例如通过Tee-Object

解决方法消除每隔一行,这将丢弃PowerShell将CR("`r"(本身解释为换行的额外行:

$i = 0
db2 ... | Where-Object { ++$i % 2 } | Tee-Object test.out

更新:此后,您在自己的答案中提供了一个基于此解决方案的方便的包装器函数

对于其他Db2 DBA尝试将powershell用作我的…

我创建了这个小破解,用于处理所有db2ps会话。

编辑您的powershell用户配置文件,创建如上所述的函数和别名:

$Home[My]Documents\Powers\Microsoft.PowerShell_profile.ps1:

# db2 settings for powershell
Set-Item -Path env:DB2CLP -value "**$$**"
# Handle db2 output, avoiding doubled lines due 'CRCRLF' pattern
Function Handle-Db2 {
$i = 0
db2 $args | Where-Object { ++$i % 2 }
}
New-Alias -Name "db2ps" Handle-Db2

现在,如果你想使用被黑客入侵的版本,你可以使用db2ps ...,而不是调用db2 ....,并获得正确的输出。

# db2ps describe table employee | Tee-Object employee.out
Data type                     Column
Column name                     schema    Data type name      Length     Scale Nulls
------------------------------- --------- ------------------- ---------- ----- ------
EMPNO                           SYSIBM    CHARACTER                    6     0 No
FIRSTNME                        SYSIBM    VARCHAR                     12     0 No
MIDINIT                         SYSIBM    CHARACTER                    1     0 Yes
LASTNAME                        SYSIBM    VARCHAR                     15     0 No
WORKDEPT                        SYSIBM    CHARACTER                    3     0 Yes
PHONENO                         SYSIBM    CHARACTER                    4     0 Yes
HIREDATE                        SYSIBM    DATE                         4     0 Yes
JOB                             SYSIBM    CHARACTER                    8     0 Yes
EDLEVEL                         SYSIBM    SMALLINT                     2     0 No
SEX                             SYSIBM    CHARACTER                    1     0 Yes
BIRTHDATE                       SYSIBM    DATE                         4     0 Yes
SALARY                          SYSIBM    DECIMAL                      9     2 Yes
BONUS                           SYSIBM    DECIMAL                      9     2 Yes
COMM                            SYSIBM    DECIMAL                      9     2 Yes
14 record(s) selected.

# db2ps describe table employee | Select-String "DEC"
SALARY                          SYSIBM    DECIMAL                      9     2 Yes
BONUS                           SYSIBM    DECIMAL                      9     2 Yes
COMM                            SYSIBM    DECIMAL                      9     2 Yes

如果IBM在windows上的db2命令上修复这种奇怪的CRCRLF行为,那就太好了。在这之前,享受吧!

问候

最新更新