取得电脑CPU的名称及速度,网卡序列号-林岚
Access软件网QQ交流学习群(群号码198465573),欢迎您的加入!
首页 >技术文章> Access数据库-模块/函数/VBA


取得电脑CPU的名称及速度,网卡序列号

发表时间:2018/1/29 23:44:24 评论(2) 浏览(616)  评论 | 加入收藏 | 复制
   
摘 要:取得电脑CPU的名称及速度

网卡序列号

正 文:

取得电脑CPU的名称及速度

Public Function ProcessorSpeed() As String
'取得电脑CPU的名称及速度

Dim MyOBJ As Object
Dim cpu As Object
Set MyOBJ = GetObject("WinMgmts:").instancesof("Win32_Processor")
For Each cpu In MyOBJ
ProcessorSpeed = cpu.Name & " " & cpu.CurrentClockSpeed & " Mhz"
Next

End Function

网卡序列号

Option Compare Database

Option Explicit

 

Private Const NCBASTAT = &H33

Private Const NCBNAMSZ = 16

Private Const HEAP_ZERO_MEMORY = &H8

Private Const HEAP_GENERATE_EXCEPTIONS = &H4

Private Const NCBRESET = &H32

 

Private Type NCB

  ncb_command As Byte

  ncb_retcode As Byte

  ncb_lsn As Byte

  ncb_num As Byte

  ncb_buffer As Long

  ncb_length As Integer

  ncb_callname As String * NCBNAMSZ

  ncb_name As String * NCBNAMSZ

  ncb_rto As Byte

  ncb_sto As Byte

  ncb_post As Long

  ncb_lana_num As Byte

  ncb_cmd_cplt As Byte

  ncb_reserve(9) As Byte ' Reserved, must be 0

  ncb_event As Long

End Type

 

Private Type ADAPTER_STATUS

  adapter_address(5) As Byte

  rev_major As Byte

  reserved0 As Byte

  adapter_type As Byte

  rev_minor As Byte

  duration As Integer

  frmr_recv As Integer

  frmr_xmit As Integer

  iframe_recv_err As Integer

  xmit_aborts As Integer

  xmit_success As Long

  recv_success As Long

  iframe_xmit_err As Integer

  recv_buff_unavail As Integer

  t1_timeouts As Integer

  ti_timeouts As Integer

  Reserved1 As Long

  free_ncbs As Integer

  max_cfg_ncbs As Integer

  max_ncbs As Integer

  xmit_buf_unavail As Integer

  max_dgram_size As Integer

  pending_sess As Integer

  max_cfg_sess As Integer

  max_sess As Integer

  max_sess_pkt_size As Integer

  name_count As Integer

End Type

 

Private Type NAME_BUFFER

  name As String * NCBNAMSZ

  name_num As Integer

  name_flags As Integer

End Type

 

Private Type ASTAT

  adapt As ADAPTER_STATUS

  NameBuff(30) As NAME_BUFFER

End Type

 

Private Declare Function Netbios Lib "netapi32.dll" (pncb As NCB) As Byte

Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (hpvDest As Any, ByVal hpvSource As Long, ByVal cbCopy As Long)

Private Declare Function GetProcessHeap Lib "kernel32" () As Long

Private Declare Function HeapAlloc Lib "kernel32" (ByVal hHeap As Long, ByVal dwFlags As Long, ByVal dwBytes As Long) As Long

Private Declare Function HeapFree Lib "kernel32" (ByVal hHeap As Long, ByVal dwFlags As Long, lpMem As Any) As Long

 

Public Function GetEthernetAddress(LanaNumber As Long) As String

  Dim udtNCB       As NCB

  Dim bytResponse  As Byte

  Dim udtASTAT     As ASTAT

  Dim udtTempASTAT As ASTAT

  Dim lngASTAT     As Long

  Dim strOut       As String

  Dim x            As Integer

 

  udtNCB.ncb_command = NCBRESET

  bytResponse = Netbios(udtNCB)

  udtNCB.ncb_command = NCBASTAT

  udtNCB.ncb_lana_num = LanaNumber

  udtNCB.ncb_callname = "* "

  udtNCB.ncb_length = Len(udtASTAT)

  lngASTAT = HeapAlloc(GetProcessHeap(), HEAP_GENERATE_EXCEPTIONS or HEAP_ZERO_MEMORY, udtNCB.ncb_length)

  strOut = ""

  If lngASTAT Then

    udtNCB.ncb_buffer = lngASTAT

    bytResponse = Netbios(udtNCB)

    CopyMemory udtASTAT, udtNCB.ncb_buffer, Len(udtASTAT)

       

     With udtASTAT.adapt

      For x = 0 To 5

        strOut = strOut & Right$("00" & Hex$(.adapter_address(x)), 2)

      Next x

    End With

    HeapFree GetProcessHeap(), 0, lngASTAT

  End If

  GetEthernetAddress = strOut

End Function

 

调用:

网卡序列号 = GetEthernetAddress(0)


Access软件网交流QQ群(群号:198465573)
 
 相关文章
返回CPU16位16进制序列号  【黄海  2004/11/20】
[荐]获取CPU信息  【fan0217  2008/7/4】
获取CPU信息  【danis  2008/10/13】
取得电脑CPU的名称及速度  【chijanze  2009/2/1】
获取本机网卡MAC码  【不祥  2010/7/20】
【源码示例】轻松获取电脑网卡地址和IP信息  【杏林求真  2012/12/13】
窗体打开,ACCESS进程显示CPU50%,对其进行优化  【爱吉瑞  2017/1/21】
 
 访客评论
2018/1/30王大哥1314

2018/1/30xiaowuo
谢谢分享

总记录:2篇  页次:1/1 9 1 :
 
 发表评论
评论内容 (必填)

常见问答
技术分类
相关资源
文章搜索
关于作者

林岚

文章分类

文章存档

友情链接