Foxtable(狐表)用户栏目专家坐堂 → [求助]关于合并数据


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

主题:[求助]关于合并数据

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


加好友 发短信
等级:婴狐 帖子:35 积分:329 威望:0 精华:0 注册:2017/8/2 17:44:00
[求助]关于合并数据  发帖心情 Post By:2017/9/26 16:53:00 [只看该作者]

Dim Book As New XLS.Book("c:\test\订单.xls")
Dim
Sheet As XLS.Sheet = Book.Sheets(0)
Tables("订单").StopRedraw()
'注意以下数组中列名称的顺序,必须和Excel表中的列顺序一致
Dim
nms() As String = {"编号","产品","客户","雇员","单价","折扣","数量","日期"}
'注意下面的循环变量从1开始,而不是从0开始,因为Excel表的第一行是标题
For n As Integer = 1 To Sheet.Rows.Count -1
    Dim
r As Row = Tables("订单").AddNew()
    For
m As Integer = 0 To nms.Length - 1
        
r(nms(m)) = Sheet(n,m).Value
    Next
Next
Tables(
"订单").ResumeRedraw()


问题:


如果合并的表我只需要其中几例,怎么操作?

[此贴子已经被作者于2017/9/26 16:54:10编辑过]

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


加好友 发短信
等级:九尾狐 帖子:2928 积分:20184 威望:0 精华:0 注册:2012/2/3 17:45:00
  发帖心情 Post By:2017/9/26 17:16:00 [只看该作者]

Dim nms() As String = {"编号","产品","客户","雇员","单价","折扣","数量","日期"}
这句改成你要的那几列名

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


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

参考代码

 

Dim dlg As New OpenFileDialog
dlg.Filter = "Excel文件|*.xls;*.xlsx"
If dlg.ShowDialog =DialogResult.OK Then
    Dim t As Table = Tables("表B")
    Dim cs As String() = {"第一列", "第二列", "第三列"}
    t.StopRedraw()
    Dim Book As New XLS.Book(dlg.FileName)
    Dim Sheet As XLS.Sheet = Book.Sheets(0)
    For n As Integer = 1 To Sheet.Rows.Count -1
        Dim r As DataRow = t.DataTable.Find("第一列 = '" & sheet(n, 0).text & "'")
        If r Is Nothing Then r = t.DataTable.AddNew()
        For i As Integer = 0 To sheet.Cols.Count -1
            Dim cname As String = sheet(0, i).text
            If array.indexof(cs,cname) >= 0 Then
                r(cname) = sheet(n, i).Text
            End If
        Next
    Next
    t.ResumeRedraw()
End If


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


加好友 发短信
等级:婴狐 帖子:35 积分:329 威望:0 精华:0 注册:2017/8/2 17:44:00
  发帖心情 Post By:2017/9/27 9:08:00 [只看该作者]

产品,客户,日期

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


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

看懂3楼代码,如果不会做,上传具体实例说明你的问题。

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


加好友 发短信
等级:婴狐 帖子:35 积分:329 威望:0 精华:0 注册:2017/8/2 17:44:00
  发帖心情 Post By:2017/11/10 17:02:00 [只看该作者]

Dim dlg As New OpenFileDialog
dlg.Filter = "Excel文件|*.xls;*.xlsx"
If dlg.ShowDialog =DialogResult.OK Then
    Dim t As Table = Tables("海报印刷投递表")
    Dim cs As String() = {"门店", "订单号", "印刷量","投递量"}
    t.StopRedraw()
    Dim Book As New XLS.Book(dlg.FileName) '定义一个Excel工作簿
    Dim Sheet As XLS.Sheet = Book.Sheets(0) '引用工作簿的第一个工作表
    For n As Integer = 2 To Sheet.Rows.Count -1
        Dim r As DataRow = t.DataTable.Find("门店 = '" & sheet(n, 0).text & "'")
        If r Is Nothing Then r = t.DataTable.AddNew()
        For i As Integer = 3 To sheet.Cols.Count -1
            Dim cname As String = sheet(0, i).text
            If array.indexof(cs,cname) >= 0 Then
                r(cname) = sheet(n, i).Text
            End If
        Next
    Next
    t.ResumeRedraw()
End If

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:测试.rar

还是不行,能不能帮我看看。

我只想导入“测试”文件表里面D、E、H、I四例到Foxtable中的对应例中。其他例不要。



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


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

Dim dlg As New OpenFileDialog
dlg.Filter = "Excel文件|*.xls;*.xlsx"
If dlg.ShowDialog =DialogResult.OK Then
    Dim t As Table = Tables("海报印刷投递表")
    Dim cs As String() = {"门店", "订单号", "印刷量","投递量"}
    t.StopRedraw()
    Dim Book As New XLS.Book(dlg.FileName) '定义一个Excel工作簿
    Dim Sheet As XLS.Sheet = Book.Sheets(0) '引用工作簿的第一个工作表
    For n As Integer = 2 To Sheet.Rows.Count -1
        Dim r As DataRow = t.DataTable.Find("门店 = '" & sheet(n, 3).text & "'")
        If r Is Nothing Then r = t.DataTable.AddNew()
        For i As Integer = 0 To sheet.Cols.count -1
            Dim cname As String = sheet(1, i).text
            If array.indexof(cs,cname) >= 0 Then
                r(cname) = sheet(n, i).Text
            End If
        Next
    Next
    t.ResumeRedraw()
End If

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


加好友 发短信
等级:婴狐 帖子:35 积分:329 威望:0 精华:0 注册:2017/8/2 17:44:00
  发帖心情 Post By:2017/11/15 13:14:00 [只看该作者]

解决了,有几个问题要问一下。

1.这个是不是列名必须要和数据源的列名相同才起作用呢?我试了一下。好像当前表的列名和数据源列名不同,他进去就是空的。
2. 

If array.indexof(cs,cname) >= 0 Then
                r(cname) = sheet(n, i).Text
End If

array.indexof(这个是什么作用,写入指定单元格位置?)


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


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

Dim dlg As New OpenFileDialog
dlg.Filter = "Excel文件|*.xls;*.xlsx"
If dlg.ShowDialog =DialogResult.OK Then
    Dim t As Table = Tables("海报印刷投递表")
    Dim cs As String() = {"门店", "订单号", "印刷量","投递量"}
    Dim cs2 As String() = {3,4,7,8}
    t.StopRedraw()
    Dim Book As New XLS.Book(dlg.FileName) '定义一个Excel工作簿
    Dim Sheet As XLS.Sheet = Book.Sheets(0) '引用工作簿的第一个工作表
    For n As Integer = 2 To Sheet.Rows.Count -1
        Dim r As DataRow = t.DataTable.Find("门店 = '" & sheet(n, 3).text & "'")
        If r Is Nothing Then r = t.DataTable.AddNew()
        For i As Integer = 0 To cs2.length-1
            r(cs(i)) = sheet(n, cs2(i)).Text
        Next
    Next
    t.ResumeRedraw()
End If

 回到顶部