添加 Base 36 到 Base 10 转换

Adding Base 36 to Base 10 conversion

我正在尝试在 的基础上构建可将数字转换为指定基数的方法。

在我的例子中,我有一个 vbs 脚本,它正在查找序列号并将字母数字字符(基数 36)输出到 txt 文件。

我想将序列号的以 10 为底的值添加到 txt 文件中。所以我得到这样的输出:

Serial Number:  ABC1234
Service Code:   22453156048

这是我的起点。该脚本运行并为我提供了一个包含序列号的 txt 文件。

On Error Resume Next

' Initialize WSH objects
Set FSO = CreateObject("Scripting.FileSystemObject")
Set Shell = WScript.CreateObject("WScript.Shell")
Set WNetwork = WScript.CreateObject("WScript.Network")

' Initialize WMI
Set WMI = GetObject("winmgmts:\.\root\cimv2")

' Find client machine name
Set ComputerInfo = WMI.ExecQuery("Select * from Win32_ComputerSystem")
For Each temp In Computerinfo
  WorkstationName = WNetwork.ComputerName
Next

Set Bios = WMI.ExecQuery("Select * from Win32_BIOS")
For Each temp In Bios
  SerN = temp.SerialNumber
Next

' Create Logfiles
Dim sDateTimeStamp
sDateTimeStamp = cStr(Year(now())) & _
                 Pad(cStr(Month(now())),2) & _
                 Pad(cStr(Day(now())),2) & _
                 Pad(cStr(Hour(now())),2) & _
                 Pad(cStr(Minute(now())),2) & _
                 Pad(cStr(Second(now())),2)

Function Pad(CStr2Pad, ReqStrLen)
  Dim Num2Pad

  Pad = CStr2Pad
  If Len(CStr2Pad) < ReqStrLen Then
    Num2Pad = String((ReqStrlen - Len(CStr2Pad)), "0")
    Pad = Num2Pad & CStr2Pad 
  End If
End Function

Set LogFile = FSO.CreateTextFile("c:\logs\" & WorkstationName & "_" & sDateTimeStamp & ".txt")

Set EnviromentVariables = Shell.Environment("PROCESS")
LogFile.Writeline("Serial Number:" & space(2) & SerN)

但是当我尝试从链接 post 添加脚本时,我没有得到任何输出文件。

On Error Resume Next

' Initialize WSH objects
Set FSO = CreateObject("Scripting.FileSystemObject")
Set Shell = WScript.CreateObject("WScript.Shell")
Set WNetwork = WScript.CreateObject("WScript.Network")

' Initialize WMI
Set WMI = GetObject("winmgmts:\.\root\cimv2")

' Find client machine name
Set ComputerInfo = WMI.ExecQuery("Select * from Win32_ComputerSystem")
For Each temp In Computerinfo
  WorkstationName = WNetwork.ComputerName
Next

Set Bios = WMI.ExecQuery("Select * from Win32_BIOS")
For Each temp In Bios
  SerN = temp.SerialNumber

  Function ToBase(ByVal n, b)
    b = 10
    n = SerN
    If b < 2 Or b > 36 Then Exit Function
    Const SYMBOLS = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"
    Do
      ToBase = Mid(SYMBOLS, n Mod b + 1, 1) & ToBase
      n = Int(n / b)
    Loop While n > 0
  End Function

  SrvCode = ToBase(SerN,10)
Next

' Create Logfiles
Dim sDateTimeStamp
sDateTimeStamp = cStr(Year(now())) & _
                 Pad(cStr(Month(now())),2) & _
                 Pad(cStr(Day(now())),2) & _
                 Pad(cStr(Hour(now())),2) & _
                 Pad(cStr(Minute(now())),2) & _
                 Pad(cStr(Second(now())),2)

Function Pad(CStr2Pad, ReqStrLen)
  Dim Num2Pad

  Pad = CStr2Pad
  If Len(CStr2Pad) < ReqStrLen Then
    Num2Pad = String((ReqStrlen - Len(CStr2Pad)), "0")
    Pad = Num2Pad & CStr2Pad 
  End If
End Function

Set LogFile = FSO.CreateTextFile("c:\logs\" & WorkstationName & "_" & sDateTimeStamp & ".txt")

Set EnviromentVariables = Shell.Environment("PROCESS")
LogFile.Writeline("Serial Number:" & space(2) & SerN)
LogFile.Writeline("Service Code:" & space(3) & SrvCode)

VBScript 中不允许嵌套函数定义。这应该引发语法错误,尽管全局 On Error Resume Next (你不应该首先使用它)。

将函数定义放在全局范围内的某处(循环外),例如通过改变这个:

Set Bios = WMI.ExecQuery("Select * from Win32_BIOS")
For Each temp In Bios
  SerN = temp.SerialNumber

  Function ToBase(ByVal n, b)
    b = 10
    n = SerN
    If b < 2 Or b > 36 Then Exit Function
    Const SYMBOLS = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"
    Do
      ToBase = Mid(SYMBOLS, n Mod b + 1, 1) & ToBase
      n = Int(n / b)
    Loop While n > 0
  End Function

  SrvCode = ToBase(SerN,10)
Next

进入这个:

Function ToBase(ByVal n, b)
  If b < 2 Or b > 36 Then Exit Function
  Const SYMBOLS = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"
  Do
    ToBase = Mid(SYMBOLS, n Mod b + 1, 1) & ToBase
    n = Int(n / b)
  Loop While n > 0
End Function

Set Bios = WMI.ExecQuery("Select * from Win32_BIOS")
For Each temp In Bios
  SerN = temp.SerialNumber
  SrvCode = ToBase(SerN,10)
Next

确保删除行 b = 10n = SerN。他们弄乱了传递给参数 bn.

的值

信用 >> http://www.4guysfromrolla.com/webtech/032400-1.shtml

我无法使用 ToBase 函数对 运行 进行计算。但是通过更多的谷歌搜索,我发现了上面的 link 并且我能够使用引用的函数来获得所需的输出。这现在允许我添加到现有脚本以在远程查找戴尔计算机服务标签时获取快速服务代码。

所以这是给出预期输出的最终工作脚本。

' Initialize WSH objects
Set FSO = CreateObject("Scripting.FileSystemObject")
Set Shell = WScript.CreateObject("WScript.Shell")
Set WNetwork = WScript.CreateObject("WScript.Network")

' Initialize WMI
Set WMI = GetObject("winmgmts:\.\root\cimv2")

' Find client machine name
Set ComputerInfo = WMI.ExecQuery("Select * from Win32_ComputerSystem")
For Each temp In Computerinfo
  WorkstationName = WNetwork.ComputerName
Next

Function baseN2dec(value, inBase)
  'Converts any base to base 10

  Dim strValue, i, x, y

  strValue = StrReverse(CStr(UCase(value)))

  For i = 0 To Len(strValue)-1
    x = Mid(strValue, i+1, 1)
    If Not isNumeric(x) Then
      y = y + ((Asc(x) - 65) + 10) * (inBase ^ i)
    Else
      y = y + ((inBase ^ i) * CInt(x))
    End If
  Next

  baseN2dec = y
End Function

Set Bios = WMI.ExecQuery("Select * from Win32_BIOS")
For Each temp In Bios                                
  SerN = temp.SerialNumber                            
  SrvCd = baseN2dec(SerN, 36)
Next

' Create Logfiles
Dim sDateTimeStamp
sDateTimeStamp = cStr(Year(now())) & _
                 Pad(cStr(Month(now())),2) & _
                 Pad(cStr(Day(now())),2) & _
                 Pad(cStr(Hour(now())),2) & _
                 Pad(cStr(Minute(now())),2) & _
                 Pad(cStr(Second(now())),2)

Function Pad(CStr2Pad, ReqStrLen)
  Dim Num2Pad

  Pad = CStr2Pad
  If Len(CStr2Pad) < ReqStrLen Then
    Num2Pad = String((ReqStrlen - Len(CStr2Pad)), "0")
    Pad = Num2Pad & CStr2Pad
  End If
End Function

Set LogFile = FSO.CreateTextFile("c:\logs\" & WorkstationName & "_" & sDateTimeStamp & ".txt")

Set EnviromentVariables = Shell.Environment("PROCESS")
LogFile.Writeline("Serial Number:" & space(2) & SerN)
LogFile.Writeline("Service Code:" & space(3) & SrvCd)