Foxtable(狐表)用户栏目专家坐堂 → 统计数据段之间的数量


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

主题:统计数据段之间的数量

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


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
统计数据段之间的数量  发帖心情 Post By:2020/9/6 16:55:00 [只看该作者]

有两个字段一个是起始哈,一个终止号都是文本类型,根据两者之间的数据怎样统计出多少数据(就像时间段统计一样)

 回到顶部
帅哥,在线噢!
有点蓝
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110744 积分:563646 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/9/6 20:28:00 [只看该作者]

数据是怎么样的?请举例说明

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


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
  发帖心情 Post By:2020/9/6 21:09:00 [只看该作者]

 假如初始号段是015659890015CW002658  终止号段是 015659890015CW002667 共应该是10张  说明 其中CW 有可能是其他字符,并且位置不确定

 回到顶部
帅哥,在线噢!
有点蓝
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


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

尾号002658是不是固定6位数,如果是,可以处理,否则没有办法

dim s1 as string = "015659890015CW002658
dim s2 as string = "015659890015CW002667

dim d1 as integer = cint(s1.substring(s1.length - 6))
dim d2 as integer = cint(s2.substring(s2.length - 6))

msgbox(d2 - d1)

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


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
  发帖心情 Post By:2020/9/6 21:53:00 [只看该作者]

截取后三位可以吗?


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

[此贴子已经被作者于2020/9/6 22:04:41编辑过]

 回到顶部
帅哥,在线噢!
有点蓝
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


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

s1.length - 3

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


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
  发帖心情 Post By:2020/9/6 22:12:00 [只看该作者]


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

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

将代码写在
DataColChanged事件中
If e.DataCol.Name = "起始号"  Then
    If e.NewValue Is Nothing  Then
        e.DataRow("充值张数") = Nothing
    Else
        Dim s1 As String = e.DataRow("终止号")
        Dim s2 As String = e.DataRow("起始号")
        Dim d1 As Integer = cint(s1.substring(s1.length - 6))
        Dim d2 As Integer = cint(s2.substring(s2.length - 6))      
        e.DataRow("充值张数") = d1-d2
        Tables("充值凭证表").Save
    End  If
End  If

[此贴子已经被作者于2020/9/6 22:36:13编辑过]

 回到顶部
帅哥,在线噢!
有点蓝
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110744 积分:563646 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/9/6 22:20:00 [只看该作者]

调试技巧:http://www.foxtable.com/webhelp/topics/1485.htm

If e.DataCol.Name = "起始号"  Then
    If e.NewValue Is Nothing  Then
        e.DataRow("充值张数") = Nothing
    Else
        Dim s1 As String = e.DataRow("终止号")
        Dim s2 As String = e.DataRow("起始号")
msgbox(s1.length)
msgbox(s1.substring(s1.length - 6))
msgbox(s2.length)
msgbox(s2.substring(s2.length - 6))
        Dim d1 As Integer = CLng(s1.substring(s1.length - 6))
        Dim d2 As Integer = CLng(s2.substring(s2.length - 6))      
        e.DataRow("充值张数") = d1-d2
        Tables("充值凭证表").Save
    End  If
End  If

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


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
  发帖心情 Post By:2020/9/6 22:40:00 [只看该作者]


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

 回到顶部
帅哥,在线噢!
有点蓝
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110744 积分:563646 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/9/6 22:54:00 [只看该作者]

做什么操作,什么代码引起的错误?

 回到顶部
总数 15 1 2 下一页