Foxtable(狐表)用户栏目专家坐堂 → 代码


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

主题:代码

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


加好友 发短信
等级:四尾狐 帖子:929 积分:6500 威望:0 精华:0 注册:2014/6/25 10:48:00
代码  发帖心情 Post By:2014/9/10 17:06:00 [只看该作者]

老师,麻烦帮我看一下这段代码错在哪里呢。谢谢!!
If User.IsRole("付款人") Then
    For Each r As Row In Tables("ZJSQB").GetCheckedRows
      Dim L As String = e.Row("付款单位") 
        Select Case e.Row("付款单位") 
          Case "高科开发建设","高科置业发展","贵州望城投资"
            If r.Isnull("子公司负责人") = False Then
                If R("SFFK") = True Then          
                  MessageBox.show("此单已付过款了,不要重复付款!")
                  Else     
                     Dim nma() As String = { "SQDBH","JHBH","HTMC","XMBM","XMMC","KSBM","KSMC","JTCWB1","ZJLB","HTBH","JSGLDW","分项名称","标段" } 'A表数据来源列
                     Dim nmb() As String = { "SQDBH","JHBH","HTMC","XMBM","XMMC","KSJM","SKDW","YFKJE","ZJLB","HTBH","FKDW","分项名称","标段" } 'B表数据接收列
                     Dim dr As DataRow = DataTables("FKB").AddNew        
                   For i As Integer = 0 To nma.Length - 1
                 dr(nmb(i)) = r(nma(i))
             End If
         Case "高科控股集团"
            If r.Isnull("JTCWB3") = False Then
                If R("SFFK") = True Then          
                  MessageBox.show("此单已付过款了,不要重复付款!")
                  Else     
                     Dim nma() As String = { "SQDBH","JHBH","HTMC","XMBM","XMMC","KSBM","KSMC","JTCWB1","ZJLB","HTBH","JSGLDW","分项名称","标段" } 'A表数据来源列
                     Dim nmb() As String = { "SQDBH","JHBH","HTMC","XMBM","XMMC","KSJM","SKDW","YFKJE","ZJLB","HTBH","FKDW","分项名称","标段" } 'B表数据接收列
                     Dim dr As DataRow = DataTables("FKB").AddNew        
                   For i As Integer = 0 To nma.Length - 1
                 dr(nmb(i)) = r(nma(i))
               End If
             End Select
    Next
          Else
      MessageBox.show("资金申请表审批流程未完全通过,不能进行付款!")
   End If
Next    
  Else
      MessageBox.show("你没有付款处理的权限!")


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


加好友 发短信
等级:贵宾 帖子:35433 积分:178524 威望:0 精华:3 注册:2013/3/30 16:36:00
  发帖心情 Post By:2014/9/10 17:08:00 [只看该作者]

提示什么错误,出现什么问题?

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


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

 回复楼主,你这段代码写得......前后要对应

 

Select Case e.Row("付款单位")
    Case "高科开发建设","高科置业发展","贵州望城投资"
        If r.Isnull("子公司负责人") = False Then
            If R("SFFK") = True Then
                MessageBox.show("此单已付过款了,不要重复付款!")
            Else
                Dim nma() As String = { "SQDBH","JHBH","HTMC","XMBM","XMMC","KSBM","KSMC","JTCWB1","ZJLB","HTBH","JSGLDW","分项名称","标段" } 'A表数据来源列
                Dim nmb() As String = { "SQDBH","JHBH","HTMC","XMBM","XMMC","KSJM","SKDW","YFKJE","ZJLB","HTBH","FKDW","分项名称","标段" } 'B表数据接收列
                Dim dr As DataRow = DataTables("FKB").AddNew
                For i As Integer = 0 To nma.Length - 1
                    dr(nmb(i)) = r(nma(i))
                Next
            End If
        End If
    Case "高科控股集团"
        If r.Isnull("JTCWB3") = False Then
            If R("SFFK") = True Then
                MessageBox.show("此单已付过款了,不要重复付款!")
            Else
                Dim nma() As String = { "SQDBH","JHBH","HTMC","XMBM","XMMC","KSBM","KSMC","JTCWB1","ZJLB","HTBH","JSGLDW","分项名称","标段" } 'A表数据来源列
                Dim nmb() As String = { "SQDBH","JHBH","HTMC","XMBM","XMMC","KSJM","SKDW","YFKJE","ZJLB","HTBH","FKDW","分项名称","标段" } 'B表数据接收列
                Dim dr As DataRow = DataTables("FKB").AddNew
                For i As Integer = 0 To nma.Length - 1
                    dr(nmb(i)) = r(nma(i))
                Next
            End If
        End If
End Select

 

 


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


加好友 发短信
等级:四尾狐 帖子:929 积分:6500 威望:0 精华:0 注册:2014/6/25 10:48:00
  发帖心情 Post By:2014/9/10 22:21:00 [只看该作者]

提示编译错误:。。。
错误代码:Select Case e.Row("付款单位")
提示,这是写在菜单事件里的代码,应该是要指定数据表的行,但不知怎么指定。

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


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

Select Case Tables("表A").Current("付款单位")

 

[此贴子已经被作者于2014-9-10 22:23:23编辑过]

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


加好友 发短信
等级:四尾狐 帖子:929 积分:6500 威望:0 精华:0 注册:2014/6/25 10:48:00
  发帖心情 Post By:2014/9/11 15:22:00 [只看该作者]

老师,我数据表中原来有列是老达式列,其表达式是IsNull([董事长2],0),现在情况有变,根据不同的条件取不同的列的值,比如,如果C列的值=D列的值,则数值=F列的值,否则,等于G列的值,是用表达式好还是通过代码计算好?如果是代码,谢老师帮忙,怎么写,写在哪里

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


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

用表达式就行:

 

iif(c= d,f,g)


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


加好友 发短信
等级:四尾狐 帖子:929 积分:6500 威望:0 精华:0 注册:2014/6/25 10:48:00
  发帖心情 Post By:2014/9/11 15:47:00 [只看该作者]

老师,下面的代码,提示红色的有错,如果去掉红色的代码,则提示绿色的有错,是写在表事件DataColChange里的,怎么修改呢?
ElseIf e.DataCol.Name = "子公司1" Then
    Dim L As String = e.Row("付款单位") 
    Select Case e.Row("付款单位") 
      Case "高科开发建设","高科置业发展","贵州望城投资"
       Dim K As String = e.DataRow("子公司1")
         Select Case K
          Case "全额同意"
            e.DataRow("子公司2") = e.DataRow("财务2")
        Case "修改后同意"
            e.DataRow("子公司2") = Nothing
        Case Else
            e.DataRow("子公司2") = "0"
        End Select
     Case "高科控股集团"
        Dim K As String = e.DataRow("子公司1")
         Select Case K
          Case "全额同意"
            e.DataRow("子公司2") = e.DataRow("CBB")
        Case "修改后同意"
            e.DataRow("子公司2") = Nothing
        Case Else
            e.DataRow("子公司2") = "0"
        End Select
     End Select


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


加好友 发短信
等级:四尾狐 帖子:929 积分:6500 威望:0 精华:0 注册:2014/6/25 10:48:00
  发帖心情 Post By:2014/9/11 15:48:00 [只看该作者]

谢谢!!




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


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

回8楼,你要贴出完整的代码,以及错误提示。

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