Hej Titta på baksidan... ;-) Det här har jag hittat någon gång, minns inte riktigt nu om det fungerar men prova gärna.Comportar
    
    
Finns det något sätt att ta reda på hur många Comportar det finns på datorn?
Och då vill jag inte ha svar som "titta på baksidan" o.s.v.
/IngvarSv: Comportar
    
    
Gå in i enhetshanteraren och kolla sen under "Portar (COM & LPT)". Vet dock inte om du kan se skillnad på fysiska portar och virtuella.
ThomasSv: Comportar
    
    
Har ett svagt minne av att den ger tillgängliga, dvs ej använda portar, inte alla som finns.
<code>
'API calls
Private Declare Function EnumPorts Lib "winspool.drv" Alias "EnumPortsA" (ByVal pName As String, ByVal Level As Long, ByVal lpbPorts As Long, ByVal cbBuf As Long, pcbNeeded As Long, pcReturned As Long) As Long
Private Declare Function lstrlenW Lib "kernel32.dll" (ByVal lpString As Long) As Long
Private Declare Sub CopyMem Lib "kernel32.dll" Alias "RtlMoveMemory" (pTo As Any, uFrom As Any, ByVal lSize As Long)
Private Declare Function HeapAlloc Lib "kernel32.dll" (ByVal hHeap As Long, ByVal dwFlags As Long, ByVal dwBytes As Long) As Long
Private Declare Function GetProcessHeap Lib "kernel32.dll" () As Long
Private Declare Function HeapFree Lib "kernel32.dll" (ByVal hHeap As Long, ByVal dwFlags As Long, lpMem As Any) As Long
'API Structures
Private Type PORT_INFO_2
    pPortName As String
    pMonitorName As String
    pDescription As String
    fPortType As Long
    Reserved As Long
End Type
Private Type API_PORT_INFO_2
    pPortName As Long
    pMonitorName As Long
    pDescription As Long
    fPortType As Long
    Reserved As Long
End Type
'Public Data Structure - up to 100 Ports Information
Private Ports(0 To 100) As PORT_INFO_2
Private Function TrimStr(strName As String) As String
  'Finds a null then trims the string
  Dim x As Integer
  x = InStr(strName, vbNullChar)
  If x > 0 Then TrimStr = Left(strName, x - 1) Else TrimStr = strName
End Function
Private Function LPSTRtoSTRING(ByVal lngPointer As Long) As String
  Dim lngLength As Long
  'Get number of characters in string
  lngLength = lstrlenW(lngPointer) * 2
  'Initialize string so we have something to copy the string into
  LPSTRtoSTRING = String(lngLength, 0)
  'Copy the string
   CopyMem ByVal StrPtr(LPSTRtoSTRING), ByVal lngPointer, lngLength
  'Convert to Unicode
  LPSTRtoSTRING = TrimStr(StrConv(LPSTRtoSTRING, vbUnicode))
End Function
'Use ServerName to specify the name of a Remote Workstation i.e. "//WIN95WKST"
'or leave it blank "" to get the ports of the local Machine
Private Function GetAvailablePorts(ServerName As String) As Long
  Dim ret As Long
  Dim PortsStruct(0 To 100) As API_PORT_INFO_2
  Dim pcbNeeded As Long
  Dim pcReturned As Long
  Dim TempBuff As Long
  Dim i As Integer
          
  'Get the amount of bytes needed to contain the data returned by the API call
  ret = EnumPorts(ServerName, 2, TempBuff, 0, pcbNeeded, pcReturned)
  'Allocate the Buffer
  TempBuff = HeapAlloc(GetProcessHeap(), 0, pcbNeeded)
  ret = EnumPorts(ServerName, 2, TempBuff, pcbNeeded, pcbNeeded, pcReturned)
  If ret Then
      'Convert the returned String Pointer Values to VB String Type
      CopyMem PortsStruct(0), ByVal TempBuff, pcbNeeded
      For i = 0 To pcReturned - 1
          Ports(i).pDescription = LPSTRtoSTRING(PortsStruct(i).pDescription)
          Ports(i).pPortName = LPSTRtoSTRING(PortsStruct(i).pPortName)
          Ports(i).pMonitorName = LPSTRtoSTRING(PortsStruct(i).pMonitorName)
          Ports(i).fPortType = PortsStruct(i).fPortType
      Next
  End If
  GetAvailablePorts = pcReturned
  'Free the Heap Space allocated for the Buffer
  If TempBuff Then HeapFree GetProcessHeap(), 0, TempBuff
End Function
</code>