Foxtable(狐表)用户栏目专家坐堂 → 交叉统计表如何定义字体颜色


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

主题:交叉统计表如何定义字体颜色

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


加好友 发短信
等级:幼狐 帖子:76 积分:735 威望:0 精华:0 注册:2020/12/20 14:02:00
交叉统计表如何定义字体颜色  发帖心情 Post By:2024/2/19 11:02:00 [只看该作者]

您好,老师,交叉统计出来的表,形成的列名,系统不能识别,请问如何对交叉统计表中的 “超期” 列定义字体颜色,代码如下:

If e.Form.Controls("DateTimePicker1").value = Nothing Then
    MessageBox.Show("请先选择查询时间 !")
    e.Cancel = True
Else If e.Form.Controls("TextBox1").value = Nothing Then
    MessageBox.Show("请先写入超期库存定义天数 !")
    e.Cancel = True
Else
    StatusBar.Message1= "正在进行数据统计,请稍等!"
    StatusBar.Message3 = Date.Today & "  " &  User.Name
    StatusBar.Refresh() '刷新状态栏
    
    Dim d As Date = e.Form.Controls("DateTimePicker1").value
    Dim KCTS As Integer = e.Form.Controls("TextBox1").value '取数 超期库存定义的天数
    Dim y As Integer = d.Year
    Dim m As Integer = d.Month
    Dim Days As Integer = Date.DaysInMonth(y,m)
    Dim FD As Date = New Date(y,m,1) '获得该月的第一天
    Dim LD As Date = New Date(y,m,Days) '获得该月的最后一天
    Dim RKRQ As Date = FD.AddDays(-KCTS) '定义超期库存的库存时间
    
    Dim bd1 As New GroupTableBuilder("统计表1",DataTables("商品车库存基础表"))
    Dim dt1 As fxDataSource
    Bd1.Groups.AddDef("关联索引列",DateGroupEnum.Day.None) '根据所属公司分组
    Bd1.Groups.AddDef("车型")
    Bd1.Groups.AddDef("配置")
    Bd1.Groups.AddDef("市场指导价")
    Bd1.Groups.AddDef("外观颜色")
    Bd1.Groups.AddDef("内饰颜色")
    Bd1.Groups.AddDef("入库日期",DateGroupEnum.Day.None,"入库日期")
    Bd1.Groups.AddDef("车款支付方式","融资方式")
    Bd1.Groups.AddDef("进货类型")
    
    Bd1.Filter ="[已定] = False and [进货类型] <> '大客户订单'"
    dt1 = bd1.BuildDataSource()
    
    Tables("查询 日报表_Table8").DataSource = dt1
    
    With DataTables("查询 日报表_Table8").DataCols  '用表达式列计算库存数据
        .Add("颜色",Gettype(String), "Substring([外观颜色],len([外观颜色])-0,1)")
        .Add("判断",Gettype(String), "IIF([入库日期] Is null,'在途',IIF([入库日期] > #" & RKRQ & "# ,'在库','超期'))")
        .Add("指导价",Gettype(String), "IsNull([市场指导价],0)/100")
    End With
    
    Dim g As New CrossTableBuilder("统计表2", DataTables("查询 日报表_Table8"))
    Dim gt As fxDataSource
    g.HGroups.AddDef("车型")
    g.HGroups.AddDef("配置")
    g.HGroups.AddDef("指导价")
    g.VGroups.AddDef("颜色")
    g.VGroups.AddDef("判断")
    g.Totals.AddDef("判断", AggregateEnum.Count, "判断")
    g.OrderByTotal = True
    g.HorizontalTotal = True
    g.VerticalTotal = True
    g.Decimals = 0
    gt = g.BuildDataSource()
    
    Tables("查询 日报表_Table7").DataSource = gt
    
    Tables("查询 日报表_Table7").AutoSizeCols() '自动设置所有列的宽度
    Tables("查询 日报表_Table7").AutoSizeHeaderRow()
    Tables("查询 日报表_Table7").SetHeaderRowHeight(25)
    Tables("查询 日报表_Table7").DefaultRowHeight = 25
    
    e.Form.Controls("Label1").text = "店端库存看板  超期库存定义'" & KCTS & "'天"
    Tables("查询 日报表_Table7").SetHeaderCellForeColor("超期",Color.Red,2)
    
End If
StatusBar.Message1= "就绪"
StatusBar.Message3 = Date.Today & "  " &  User.Name
StatusBar.Refresh() '刷新状态栏

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


加好友 发短信
等级:超级版主 帖子:107147 积分:544978 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2024/2/19 11:13:00 [只看该作者]

没看到有超期这个列,如果是单元格的值,到drawcell事件处理

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


加好友 发短信
等级:幼狐 帖子:76 积分:735 威望:0 精华:0 注册:2020/12/20 14:02:00
  发帖心情 Post By:2024/2/19 11:21:00 [只看该作者]

  老师,“超期”  列是通过增加的 “判断” 列,通过交叉统计生成的,在这种情况下,通过代码能否设置字体颜色
    With DataTables("查询 日报表_Table8").DataCols  '用表达式列计算库存数据
        .Add("颜色",Gettype(String), "Substring([外观颜色],len([外观颜色])-0,1)")
        .Add("判断",Gettype(String), "IIF([入库日期] Is null,'在途',IIF([入库日期] > #" & RKRQ & "# ,'在库','超期'))")
        .Add("指导价",Gettype(String), "IsNull([市场指导价],0)/100")
    End With

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


加好友 发短信
等级:超级版主 帖子:107147 积分:544978 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2024/2/19 11:23:00 [只看该作者]

那列名是"判断"啊,单元格的值是'超期',只能到drawcell事件处理

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


加好友 发短信
等级:幼狐 帖子:76 积分:735 威望:0 精华:0 注册:2020/12/20 14:02:00
  发帖心情 Post By:2024/2/19 11:23:00 [只看该作者]

谢谢老师

 回到顶部