Rss & SiteMap

Foxtable(狐表) http://www.foxtable.com

新一代数据库软件,完美融合Access、Foxpro、Excel、vb.net之优势,人人都能掌握的快速软件开发工具!
共13 条记录, 每页显示 10 条, 页签: [1] [2]
[浏览完整版]

标题:这样的表格,狐表里面要怎么弄?

1楼
shyilin 发表于:2017/9/6 20:25:00

图片点击可在新窗口打开查看此主题相关图片如下:原.jpg
图片点击可在新窗口打开查看

图片点击可在新窗口打开查看此主题相关图片如下:改.jpg
图片点击可在新窗口打开查看
2楼
shyilin 发表于:2017/9/6 20:27:00
用合并模式   标准和自由都不行呢 ?还有什么其他方法吗?求解答
3楼
有点甜 发表于:2017/9/6 20:30:00
 只能用合并模式,你用合并模式有什么问题?
4楼
shyilin 发表于:2017/9/6 20:51:00
用标准模式,合计不能合并,用自由模式,合计价格一样的话就合并起来,那就不对了
5楼
shyilin 发表于:2017/9/6 20:57:00
还在?
6楼
shyilin 发表于:2017/9/6 21:28:00
这样不管了?
7楼
有点甜 发表于:2017/9/6 22:20:00

mark 合并模式

 

Dim t As Table = Tables("表a")
Dim cs As String() = {"第一列", "第二列", "第五列"}

'取消合并
Dim ls As new List(of object)
For Each r As object In t.Grid.MergedRanges
        ls.add(r)
Next
For Each r As object In ls
    t.Grid.MergedRanges.Remove(r)
Next

'设置合并
For i As Integer = 0 To cs.length-1
    Dim top As Integer = 0
    For j As Integer = 1 To t.Rows.count-1
        Dim r1 As Row = t.Rows(j-1)
        Dim r2 As Row = t.Rows(j)
        Dim same As Boolean = True
        For k As Integer = 0 To i
            If r1(cs(k)) <> r2(cs(k)) Then
                same = False
                Exit For
            End If
        Next
       
        If same = False  Then
            t.Grid.AllowMerging = C1.Win.C1FlexGrid.AllowMergingEnum.Custom
            Dim rng As C1.Win.C1FlexGrid.CellRange = t.Grid.GetCellRange(top+t.HeaderRows, t.cols(cs(i)).Index+1, j+t.HeaderRows-1, t.cols(cs(i)).Index+1)
            t.Grid.MergedRanges.add(rng)
           
            Top = j
        ElseIf j = t.rows.count-1 Then
            Dim rng As C1.Win.C1FlexGrid.CellRange = t.Grid.GetCellRange(top+t.HeaderRows, t.cols(cs(i)).Index+1, j+t.HeaderRows, t.cols(cs(i)).Index+1)
            t.Grid.MergedRanges.add(rng)
        End If
    Next
   
Next

 

8楼
nxhylczh 发表于:2019/1/14 10:52:00
贴的这代码就不知道啥意思
能否按发题者的表格写一段代码?
9楼
有点甜 发表于:2019/1/14 10:58:00
以下是引用nxhylczh在2019/1/14 10:52:00的发言:
贴的这代码就不知道啥意思
能否按发题者的表格写一段代码?

 

这里改成自己的表和列

 

Dim t As Table = Tables("表a")
Dim cs As String() = {"第一列", "第二列", "第五列"}

10楼
chen37280600 发表于:2019/1/14 11:47:00
这种一对多的关系,从数据库设计来说,应该是通过父子表的形式存储。然后导出Excel的时候,生成这种样式。这样将来维护才更方便。

不然现在你一个人下面有2个产品,如果将来陆续增加,你的合并单元格就要拼命排序和更改
共13 条记录, 每页显示 10 条, 页签: [1] [2]

Copyright © 2000 - 2018 foxtable.com Tel: 4000-810-820 粤ICP备11091905号

Powered By Dvbbs Version 8.3.0
Processed in .02734 s, 2 queries.