Rss & SiteMap

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

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

标题:数据能否从其它列取值?

1楼
cjguan 发表于:2011/12/24 10:41:00

我的表中有三个字段,起始日期,起始年,起始月。起始年和起始月的值取自起始日期,能否让其自动生成?谢谢!

或者在报表设计中能否用什么函数将起始年和起始月从起始日期中取出来?

[此贴子已经被作者于2011-12-24 10:45:13编辑过]
2楼
blackzhu 发表于:2011/12/24 11:01:00
 

Dim d As Date = #12/31/2007#
Output.Show(d
.Year
)

 

你在命令窗口试试,这样得到的结果

3楼
blackzhu 发表于:2011/12/24 11:01:00
如果不懂写法再提.
4楼
yangming 发表于:2011/12/24 11:02:00

表属性:

DataColChanged事件中代码:

 

If e.DataCol.Name = "起始日期" Then '如果更改的是起始日期列
    If e.DataRow.IsNull("起始日期") Then '起始日期是否为空
        e.DataRow("年") = Nothing '如果为空,则清除年
        e.DataRow("月") = Nothing '如果为空,则清除月
    Else
        '否则从起始日期列中提取年和月
        e.DataRow("年") = e.DataRow("起始日期").Year
        e.DataRow("月") = e.DataRow("起始日期").Month
    End If
End If

5楼
yangming 发表于:2011/12/24 11:10:00

也可以不用在表中列出年和月的列,只要报表中打印出来,下面随便做了一个示例,你放到窗口中的按钮中打印一下就知道了

Dim doc As New PrintDoc '定义一个报表
Dim rt As New prt.RenderTable() '定义一个表格对象
Dim rx As New prt.RenderText '定义一个文本对象
Dim CurRow As Row = Tables("表A").Current
'加入标题
rx.text = "员工资料卡"
rx.Style.FontBold = True '字体加粗
rx.Style.FontSize = 16 '大体大小为16磅
rx.Style.TextAlignHorz = prt.AlignHorzEnum.Center '水平居中排列
rx.Style.Spacing.Bottom = 3 '和下面的对象(表格)距离3毫米
doc.Body.Children.Add(rx) '加入到报表中
'指定行数?列数?列宽?行高
rt.Rows.Count = 7 '设置总行数
rt.Cols.Count = 5 '设置总列数
rt.Height = 80 '设置表格的高度为80毫米
rt.Rows(6).Height = 40 '设置第7行(显示备注的行)的高度为40毫米,剩余高度被平均分排到其他行
rt.Cols(0).Width = 24 '设置前四列的宽度,剩余的宽度被分配给5列(显示图片的那列)
rt.Cols(1).Width = 35
rt.Cols(2).Width = 24
rt.Cols(3).Width = 40
rt.Cells(0,0).Text= "起始日期"
rt.Cells(0,1).Text = CurRow("起始日期")
rt.Cells(1,0).Text= "年"
rt.Cells(1,1).Text = CurRow("起始日期").Year

rt.Cells(1,2).Text= "月"
rt.Cells(1,3).Text = CurRow("起始日期").Month
doc.Body.Children.Add(rt) '将表格对象加入到报表中
Doc.Preview() '预览

6楼
jxkqf 发表于:2011/12/24 22:04:00

杨版之热情、敬业 

令人感动!!!!

7楼
cjguan 发表于:2011/12/24 22:26:00
谢谢热心指导。不过我在提问中没有表达清楚。起始日期字段是文本,如20101224,不是日期格式,最好是在报表中用函数取起始日期的前四位成为起始年,等。我不知应该怎么写?请指点。
8楼
yangming 发表于:2011/12/24 23:23:00

五楼的代码的这几句改成这样就可以了,看红字部分

 

rt.Cells(1,0).Text= "年"
rt.Cells(1,1).Text = Left(CurRow("起始日期"),4)
rt.Cells(1,2).Text= "月"
rt.Cells(1,3).Text =Mid(CurRow("起始日期"),5,2)

共8 条记录, 每页显示 10 条, 页签: [1]

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

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