Foxtable(狐表)用户栏目专家坐堂 → MAC地址递增


  共有3297人关注过本帖树形打印复制链接

主题:MAC地址递增

帅哥哟,离线,有人找我吗?
huhu
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1182 积分:8225 威望:0 精华:0 注册:2015/3/30 10:44:00
MAC地址递增  发帖心情 Post By:2019/1/29 11:43:00 [只看该作者]

现在有2个文本框,
起始文本框记录的是起始MAC地址9845.622f.2b00
截至文本框记录的是截至MAC地址9845.622f.2b11
如何做到在表A把这18号增加进去。我现在不知道怎么计算。
9845.622f.2b00
9845.622f.2b01
9845.622f.2b02
9845.622f.2b03
9845.622f.2b04
9845.622f.2b05
9845.622f.2b06
9845.622f.2b07
9845.622f.2b08
9845.622f.2b09
9845.622f.2b0a
9845.622f.2b0b
9845.622f.2b0c
9845.622f.2b0d
9845.622f.2b0e
9845.622f.2b0f
9845.622f.2b10
9845.622f.2b11

 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2019/1/29 12:37:00 [只看该作者]

Dim s1 = "2b00"
Dim s2 = "2b11"
For i As Integer = HexToDec(s1) To HexToDec(s2)
    output.show(DecToHex(i))
Next

 回到顶部
帅哥哟,离线,有人找我吗?
huhu
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1182 积分:8225 威望:0 精华:0 注册:2015/3/30 10:44:00
  发帖心情 Post By:2019/1/29 13:33:00 [只看该作者]

为什么是后四位而不是完整的mac地址?
最好是完整的mac地址,只取后四位,万一数据很大,前面的肯定会变。


图片点击可在新窗口打开查看此主题相关图片如下:qq截图20190129132834.png
图片点击可在新窗口打开查看


 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2019/1/29 15:00:00 [只看该作者]

Dim s1 = "9845622f2b00"
Dim s2 = "9845622f2b11"
For i As Decimal = HexToDec(s1) To HexToDec(s2)
    output.show(DecToHex(i))
Next

 回到顶部
帅哥哟,离线,有人找我吗?
huhu
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1182 积分:8225 威望:0 精华:0 注册:2015/3/30 10:44:00
  发帖心情 Post By:2019/1/30 10:59:00 [只看该作者]

mac地址中只能出现A-F的字母,如果是其他字母就是格式不对。红色的代码怎么写?

Dim cfmac As WinForm.TextBox = e.Form.Controls("TextBox1")
Dim qsmac As WinForm.TextBox = e.Form.Controls("TextBox2")
Dim jzmac As WinForm.TextBox = e.Form.Controls("TextBox3")
Dim gsjc As WinForm.TextBox = e.Form.Controls("TextBox4")
DataTables("临时MAC").SQLDeleteFor("_identify is not null")
DataTables("临时MAC").RemoveFor("_identify is not null")
cfmac.text = ""
Dim str1 As String = qsmac.text.Replace(".","").Replace(":","").trim()  ‘起始mac
Dim str2 As String = jzmac.text.Replace(".","").Replace(":","").trim() ’截至mac
Dim str12 As String 
If str1.Length <> 12  or  字母只能是A-F then
XXXXX
else
Dim str As String
If gsjc.text = "" Then
    str &= "公司简称不能为空,"
End If
If str1 = "" Then
    str &= "起始MAC不能为空,"
End If
If str2 = "" Then
    str &= "截至MAC不能为空"
End If
If str > "" Then
    MessageBox.show(str.trim(","),"不能为空",MessageBoxButtons.OK,MessageBoxIcon.Error)
Else
    For i As Decimal = HexToDec(str1) To HexToDec(str2)
        Dim dr As DataRow = DataTables("临时MAC").AddNew
        dr("mac") = DecToHex(i)
    Next
    DataTables("临时MAC").Save
end if
end if


 回到顶部
帅哥哟,离线,有人找我吗?
有点甜
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2019/1/30 11:31:00 [只看该作者]

用正则判断,如

 

Dim pattern As String =  "^[0-9.a-zA-Z]{14}$"
Dim txt As String = "9845.622f.2b00"
Dim rgx = new System.Text.RegularExpressions.Regex(pattern)
If rgx.isMatch(txt) = False Then
    msgbox("错误")
Else
    msgbox("正确")
End If


 回到顶部
帅哥哟,离线,有人找我吗?
huhu
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1182 积分:8225 威望:0 精华:0 注册:2015/3/30 10:44:00
  发帖心情 Post By:2019/1/30 14:09:00 [只看该作者]

帮助里面好像没搜到正则的内容。
或者你能把每个语句大概啥意思讲一下。

 回到顶部
帅哥哟,离线,有人找我吗?
有点蓝
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110574 积分:562760 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/1/30 17:17:00 [只看该作者]


 回到顶部