Foxtable(狐表)用户栏目专家坐堂 → 较为完美的插入行的方法(第二次更新)


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

主题:较为完美的插入行的方法(第二次更新)

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


加好友 发短信 一级勋章
等级:MVP荣誉狐 帖子:5154 积分:31434 威望:0 精华:8 注册:2008/9/8 12:27:00
  发帖心情 Post By:2009/11/24 14:09:00 [只看该作者]

以下是引用狐狸爸爸在2009-11-24 13:21:00的发言:


我改了一下。

正式收藏了~~   不收白不收~  图片点击可在新窗口打开查看


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


加好友 发短信 一级勋章
等级:MVP荣誉狐 帖子:5154 积分:31434 威望:0 精华:8 注册:2008/9/8 12:27:00
  发帖心情 Post By:2009/11/24 14:25:00 [只看该作者]

最后补上下面代码,就不用担心ID列看上去乱哄哄的了,且可以让你点鼠标点到手指发麻为止 :
For i As Integer = 0 To CurrentTable.Rows.Count-1
    CurrentTable(i,"ID") = i+1
next

不加这段代码,但你一直点击按钮增加行时,当达到12位小数时,就会乱套了~  ,

另外,列属性中最大小数位数,设置到超过12位数时,就会出错!!!~~~(我是设置到28位时出错,一路减少的12位及以下,还是出错??? 请检查一下
[此贴子已经被作者于2009-11-24 14:25:41编辑过]

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


加好友 发短信
等级:九尾狐 帖子:2649 积分:19384 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2009/11/24 14:26:00 [只看该作者]

SSqq的插入行代码有什么问题吗?狐爸的ID序号小数点太多


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


加好友 发短信 一级勋章
等级:MVP荣誉狐 帖子:5154 积分:31434 威望:0 精华:8 注册:2008/9/8 12:27:00
  发帖心情 Post By:2009/11/24 14:28:00 [只看该作者]

以下是引用实话实说在2009-11-24 14:26:00的发言:

SSqq的插入行代码有什么问题吗?狐爸的ID序号小数点太多

看12楼   

ssqq的代码中Dim cname As String = "InsertRowTemp"  字符型的肯定不行的,排序后就会乱套的,会排成1、10、11、2、20、22、。。。。。3、30、31、 、、、、、、

[此贴子已经被作者于2009-11-24 15:03:06编辑过]

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


加好友 发短信
等级:九尾狐 帖子:2649 积分:19384 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2009/11/24 14:46:00 [只看该作者]

以下是引用mr725在2009-11-24 14:25:00的发言:
最后补上下面代码,就不用担心ID列看上去乱哄哄的了,且可以让你点鼠标点到手指发麻为止 :
For i As Integer = 0 To CurrentTable.Rows.Count-1
    CurrentTable(i,"ID") = i+1
next

不加这段代码,但你一直点击按钮增加行时,当达到12位小数时,就会乱套了~  ,

另外,列属性中最大小数位数,设置到超过12位数时,就会出错!!!~~~(我是设置到28位时出错,一路减少的12位及以下,还是出错??? 请检查一下
[此贴子已经被作者于2009-11-24 14:25:41编辑过]

加在哪里?


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


加好友 发短信 一级勋章
等级:MVP荣誉狐 帖子:5154 积分:31434 威望:0 精华:8 注册:2008/9/8 12:27:00
  发帖心情 Post By:2009/11/24 15:01:00 [只看该作者]

以下是引用实话实说在2009-11-24 14:46:00的发言:

加在哪里?

狐爸1楼例子的按钮代码的最后面啊~   你是老狐了,该看的明白的~ 


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


加好友 发短信
等级:九尾狐 帖子:2649 积分:19384 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2009/11/24 15:05:00 [只看该作者]

加了,不行

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


加好友 发短信
等级:九尾狐 帖子:2649 积分:19384 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2009/11/24 15:06:00 [只看该作者]

我现在是头驴,还不是狐

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


加好友 发短信 一级勋章
等级:MVP荣誉狐 帖子:5154 积分:31434 威望:0 精华:8 注册:2008/9/8 12:27:00
  发帖心情 Post By:2009/11/24 15:09:00 [只看该作者]

先把ID列按序列充填好:1、2、3、、、、、、、n;按钮代码 如下 :

Dim i As Integer = CurrentTable.Position
Dim v AS double
If i < 0 Then
    CurrentTable.AddNew()
    Return
ElseIf i = 0 Then
    v = CurrentTable.Current("ID") - 1
    CurrentTable.AddNew()("ID") = v
Else
    Dim v1 As Double = CurrentTable.Rows(CurrentTable.Position - 1)("ID")
    Dim v2 As Double = CurrentTable.Current("ID")
    Dim s1 As String = v1
    Dim s2 As String = v2
    Dim c1 As integer =  0
    Dim c2 As Integer =  0
    If s1.IndexOf(".") > 0 Then
        c1 = s1.Length - s1.IndexOf(".") -1
    End If
    If s2.IndexOf(".") > 0 Then
        c2 = s2.Length - s2.IndexOf(".") -1
    End If
    If c1 = c2 Then
        v = v1 + (v2 - v1) / 10 * 9
    Else
       Dim c As Integer = Math.Max(c2,c1)
       Dim n As Integer = 1
       v = v2 -  1 / 10 ^ c
       If v <= v1
           v = v2 - 1 / 10 ^ (c + 1)
       End If
    End If
    CurrentTable.DataTable.AddNew()("ID") = v
End If
CurrentTable.Sort = "ID"
CurrentTable.Position = CurrentTable.FindRow("ID = " & v,0,True)

For ii As Integer = 0 To CurrentTable.Rows.Count-1
    CurrentTable(ii,"ID") = ii+1
next


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


加好友 发短信
等级:九尾狐 帖子:2649 积分:19384 威望:0 精华:1 注册:2008/9/12 9:19:00
  发帖心情 Post By:2009/11/24 15:23:00 [只看该作者]

以下是引用mr725在2009-11-24 15:09:00的发言:

先把ID列按序列充填好:1、2、3、、、、、、、n;按钮代码 如下 :

Dim i As Integer = CurrentTable.Position
Dim v AS double
If i < 0 Then
    CurrentTable.AddNew()
    Return
ElseIf i = 0 Then
    v = CurrentTable.Current("ID") - 1
    CurrentTable.AddNew()("ID") = v
Else
    Dim v1 As Double = CurrentTable.Rows(CurrentTable.Position - 1)("ID")
    Dim v2 As Double = CurrentTable.Current("ID")
    Dim s1 As String = v1
    Dim s2 As String = v2
    Dim c1 As integer =  0
    Dim c2 As Integer =  0
    If s1.IndexOf(".") > 0 Then
        c1 = s1.Length - s1.IndexOf(".") -1
    End If
    If s2.IndexOf(".") > 0 Then
        c2 = s2.Length - s2.IndexOf(".") -1
    End If
    If c1 = c2 Then
        v = v1 + (v2 - v1) / 10 * 9
    Else
       Dim c As Integer = Math.Max(c2,c1)
       Dim n As Integer = 1
       v = v2 -  1 / 10 ^ c
       If v <= v1
           v = v2 - 1 / 10 ^ (c + 1)
       End If
    End If
    CurrentTable.DataTable.AddNew()("ID") = v
End If
CurrentTable.Sort = "ID"
CurrentTable.Position = CurrentTable.FindRow("ID = " & v,0,True)

For ii As Integer = 0 To CurrentTable.Rows.Count-1
    CurrentTable(ii,"ID") = ii+1
next

好使


 回到顶部
总数 32 上一页 1 2 3 4 下一页