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


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

主题:StateFilter

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


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

StateFilter

状态筛选,StateFilterEnum型枚举,可选值有:

Default:            显示所有行
Added :             显示新增行
Modified :          显示已经修改的行
UnChanged :         显示没有修改的行
Original:           原始视图
ModifiedOriginal:   原始视图(仅修改行)

例如在当前表显示新增行:

CurrentTable.StateFilter = StateFilterEnum.Added


导入代码如下。就是希望只把新增行加载出来。

Dim App As New MSExcel.Application

try

    If Forms("正在导入").Opened = False Then

        Forms("正在导入").open

    End If

    Dim Wb As MSExcel.Workbook = App.WorkBooks.Open("D:\物料编码.XLS")

    Dim Ws As MSExcel.WorkSheet = Wb.WorkSheets(1)

    Tables("物料编码").StopRedraw()

    '注意以下数组中列名称的顺序,必须和Excel表中的列顺序一致

    Dim ra = ws.UsedRange

    Dim nms() As String = {"物料编码","物料名称","原型物料编码","原型物料名称"}

    '注意下面的循环变量从1开始,而不是从0开始,因为Excel表的第一行是标题

    For n As Integer = 2 To ra.Rows.Count

        Dim wlbm As String = ws.cells(n,1).Text

        If DataTables("物料编码").SQLFind("物料编码 = '" & wlbm & "'") Is Nothing Then '如果不存在同编号的计划表

            Dim r As Row = Tables("物料编码").AddNew()

            For m As Integer = 0 To nms.Length - 1

                r(nms(m)) = ws.cells(n,m+1).Value

                r.save

            Next

        End If

    Next

    Tables("物料编码").ResumeRedraw()

    'DataTables("物料编码").LoadFilter = ""

    'DataTables("物料编码").Load

    Tables("物料编码").StateFilter = StateFilterEnum.Added

    If Forms("正在导入").Opened = True Then

        Forms("正在导入").close

        MessageBox.show("物料编码导入完成","导入完成",MessageBoxButtons.OK,MessageBoxIcon.Information)

    End If

catch ex As exception

finally

    app.quit

End try


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


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

删除这句代码 r.save

 


 回到顶部