Foxtable(狐表)用户栏目专家坐堂 → [求助]我想显示成这样。怎么做


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

主题:[求助]我想显示成这样。怎么做

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


加好友 发短信
等级:婴狐 帖子:33 积分:375 威望:0 精华:0 注册:2011/4/5 17:15:00
[求助]我想显示成这样。怎么做  发帖心情 Post By:2012/1/4 2:20:00 [只看该作者]

我想在第三列输入100101,显示出来的是第二列的1001行b和100101行的c合成也的,如第四列第一行的样子。

注:会计科目 显示用。
    科目编号 只用一列
  10  a   100101    b\c
   1001  b       
   100101   c      
[此贴子已经被作者于2012-1-4 2:23:31编辑过]

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


加好友 发短信
等级:管理员 帖子:47448 积分:251048 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2012/1/4 8:31:00 [只看该作者]

没看懂你的意思

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


加好友 发短信
等级:八尾狐 帖子:1812 积分:12993 威望:0 精华:14 注册:2008/10/11 18:07:00
  发帖心情 Post By:2012/1/4 9:38:00 [只看该作者]

If e.DataCol.Name = "第三列"  Then
    Dim dr1,dr2 As DataRow
    Dim s As String = e.NewValue
    If s Is Nothing Then
        e.DataRow("第四列")= Nothing
    Else
        dr1 = DataTables("表A").Find("第一列 = '" & s.substring(0,s.length-2) & "'")
        dr2 = DataTables("表A").Find("第一列 = '" & s  & "'")
        s =Nothing
        If dr1 IsNot Nothing Then
            s = dr1("第二列") & "/"
        End If
        If dr2 IsNot Nothing Then
            s+=dr2("第二列")
        End If
        e.DataRow("第四列")= s
    End If
End If

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


加好友 发短信
等级:五尾狐 帖子:1128 积分:11029 威望:0 精华:2 注册:2008/9/1 10:45:00
  发帖心情 Post By:2012/1/4 9:38:00 [只看该作者]

表事件DataColChanged:

 

If e.DataCol.Name = "第三列" Then
    If e.NewValue.Length = 6 Then
        Dim km As  String
        Dim dr As DataRow
        dr = DataTables("表A").Find("第一列 = '" & e.NewValue.SubString(0,4) & "'")
        If dr IsNot Nothing Then '如果找到的话
            km=dr("第二列")
        End If
        Dim dr1 As DataRow
        dr1 = DataTables("表A").Find("第一列 = '" & e.NewValue & "'")
        If dr1 IsNot Nothing Then '如果找到的话
            km=km & "\" & dr1("第二列")
        End If
        e.DataRow("第四列")=km
    End If
End If


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


加好友 发短信
等级:婴狐 帖子:33 积分:375 威望:0 精华:0 注册:2011/4/5 17:15:00
  发帖心情 Post By:2012/1/4 13:44:00 [只看该作者]

谢谢楼上的代码,我又做了点修改,用在Drawcell事件里,这多的代码会不会太负担Drawcell,请帮修改和优化一下,谢谢了。

If e.Row.IsNull("第三列") = False AndAlso e.Col.Name = "第三列"  Then
    Dim sor As Long = 2 '科目编号位数
    Dim ii As Long = 4 '一级科目编号位数
    Dim s As String = e.Row("第三列") '输入值
    If s.Length<ii OrElse (s.Length-ii) Mod sor<>0 Then
        e.Row("第三列")=Nothing
    Else
        Dim dr1,dr2 As DataRow
        Dim ss As String =Nothing
        '----        
        For i As Long =ii To s.Length Step sor
            dr1 = DataTables("表A").Find("第一列 = '" & s.substring(0,i) & "'")
            Dim va As String =""
            If dr1 Is Nothing Then
                messagebox.Show("会计科目编号未使用","错误")
                e.Row("第三列")=Nothing
                Exit For
            Else
                If I<s.Length Then va="\"
                
                ss= ss & dr1("第二列") & va
            End If
        Next
        '---
        e.Text = ss
    End If    
End If
[此贴子已经被作者于2012-1-5 2:09:21编辑过]

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


加好友 发短信
等级:婴狐 帖子:33 积分:375 威望:0 精华:0 注册:2011/4/5 17:15:00
  发帖心情 Post By:2012/1/4 22:22:00 [只看该作者]

如上

 回到顶部