社区
Delphi
帖子详情
如何在DBGRID中显示TEXT字段 ?
mjyalik
2000-08-04 10:26:00
对于Text字段, 在DBGrid中只能显示 MEMO, 不能显示其内容, 如何解决 ?
...全文
84
回复
打赏
收藏
如何在DBGRID中显示TEXT字段 ?
对于Text字段, 在DBGrid中只能显示 MEMO, 不能显示其内容, 如何解决 ?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
delphi用ASGSQlite3访问sqlite数据库实例
delphi7用ASGSQlite3访问sqlite数据库实例: 1、用aducom sqlite3连接数据库,操作非常简单,跟用ado访问一样 2、用Navicat制作数据库,
显示
正常,但数据库
中
是乱码,不影响程序运行时的
显示
。 3、支持在设计时
显示
数据库内容。设置ASQLite3Table的active为true. 4、用Navicat制作数据库时,
text
字段
要设置长度,否则系统认为它是memo
字段
,在
db
grid
中
显示
为[MEMO] 5、可下载本人上传的ASGSQLite3 For delphi7.rar使用。
打印软件(打印 datasource,
db
grid
,string
grid
)
reprint 使用说明 本人长期使用delphi做数据库的开发,报表控件使用Quickrpt,在打印上经常遇到一些问题,于是自己经常编写一部分打印的程序,经过总结开发了这个控件。 本控件可打印 datasource,
db
grid
,string
grid
. 一 、控件属性: 1、colstitle 设置报表的列标题属性 (1)alignment 列标题对齐方式。 (2)font 列标题字体 (3)print 设置是否打印列标题 (4)rowspace 列标题行的高度 2、datasource 选择要打印的datasource 3、
db
grid
选择要打印的
db
grid
4、string
grid
选择要打印的string
grid
5、detail 设置要打印的明细数据属性 (1)arrange 设置明细
字段
排列方向 Horizontal 横向打印(默认的一般打印) Vertical 竖向打印(
字段
竖向排列适合打印
字段
内容较长的报表如“会议纪录”) (2)aotureturn 打印明细
字段
时,如果
字段
超过列的宽度是否允许自动换行 (3)colsline 设置竖线属性引用tpen类 (4)footer 设置明细尾 (5)frame 设置明细边框属性引用tpen类 (6)head 设置明细头同footer (7)rowsline 设置横线属性引用tpen类 (8)rowspace 设置明细行的高度 (9)top 明细与标题的距离 6、page 设置纸张的上下左右边距 7、pagefooter 设置页脚同明细尾 8、pageheader 设置页眉同页脚 9、printobject 选择要打印的对象 (datasource 、
db
grid
、 string
grid
) 10、title 设置标题类页眉、页脚 二 、控件方法: (1) preview 预览 (2) print 打印 (3) SaveToFile() 保存为报表文件 (4) SaveToStream() 保存为流(然后就可把整个报表存到数据库了很方便哦! ~_~) (5) PrintFile() 打印报表文件 (6) PrintStream() 打印流(流的数据库存取就不用多说了吧) (7) PreviewFile() 预览文件 (8) PreviewStream() 预览流 (9) OptionToStream() 报表的属性保存为流 (10) OptionFromStream() 从流
中
得到报表属性 三、 控件事件: AfterPrint 打印后 BeforePrint 打印前 (本来很多事件,但没有预览,后来加上预览以及一些方法后实现很困难就去掉了!) 四、注意事项 (1)
text
属性,输入“¦;;;;;;;#¦;;;;;;;”打印页码值,如果想打印页码可输入“第¦;;;;;;;#¦;;;;;;;页” 输入“¦;;;;;;;RecordCount¦;;;;;;;”打印 记录数 (2) 不同的打印机,打印和预览效果可能有一点点不同(保证数据打印完全正确一致)。本人用一台针式和一台激光打印机做测试,开始差别较大后经过调试基本一致,不知其他打印机如何。 就这些个吧基本满足了我的软件开发需要,解决了很多问题,关键是做报表省了很大力气,当然了很复杂的报表还是要其它报表控件来解决。如果有其他问题或好的建议可与我联系。 程序设计:吴进昊 E-mail :jinhaowu@hotmail.com qq :54254770 2003.01.03
RePrint表格打印控件(打印 datasource,
db
grid
,string
grid
)
功能更加强劲,增加多行表头的功能,新增更多事件,加强了打印期间对报表样式 的控制,可随意改变打印内容。 reprint 使用说明 本控件可打印 datasource,
db
grid
,string
grid
. 一 、控件属性: 1、colstitle 设置报表的列标题属性 (1) Print:boolean;;是否打印 (2) Font:tfont;;字体 (3) Rowsline:tpen;;横线样式 (4) Colsline:tpen;;竖线样式 (5) Alignment:talignment;;对齐方式 (6) Rowspace:integer;;行间距 (7) EveryPage:boolean;;是否每页打印 (8) EveryRow:boolean;;是否每行打印 (9) titlearray:tstrings;;怎加标题组 (使用方法见附带demo) (10) rows:integer;;设置默认列标题打印行数 2、datasource 绑定 datasource 3、
db
grid
绑定
db
grid
4、string
grid
绑定 string
grid
PrintObject 选择打印的对象(datasource 、
db
grid
、 string
grid
) 5、pagefooter 页脚 pageheader 页眉 (1)
Text
:string;;内容 (2) Font:tfont;;字体 (3) Print:boolean;;是否打印 (4) Alignment:talignment;;对齐方式 6、detail 设置要打印的明细数据属性 (1)arrange 设置明细
字段
排列方向 Horizontal 横向打印(默认的一般打印) Vertical 竖向打印(
字段
竖向排列适合打印
字段
内容较长的报表如“会议纪录”) (2)aotureturn 打印明细
字段
时,如果
字段
超过列的宽度是否允许自动换行 (3)colsline 设置竖线属性引用tpen类 (4)footer 设置明细尾 (设置同pagefooter 页脚 pageheader 页眉) (5)frame 设置明细边框属性引用tpen类 (6)head 设置明细头(设置同pagefooter 页脚 pageheader 页眉) (7)rowsline 设置横线属性引用tpen类 (8)rowspace 设置明细行的高度 (9)top 明细与标题的距离 (10)Alignment对齐方式 7、page 设置纸张 (1) leftmargin:real;;左边距 (2) rightmargin:real;;右边距 (3) topmargin:real;;顶边距 (4) bottommargin:real;;底边距 (5) pagesize:TPageSize;;纸张类型 (6) Height:real;;高度 (7) width:real;;宽度 (8) Orientation:TPrinterOrientation;;打印方向 注意:设置纸张的宽度和高度需把pagesize设为Custom 8、title 设置标题 (1) Print:boolean;; 是否打印 (2)
Text
:tstrings;; 内容可设置多行 (3) Font:tfont;;字体 (4) Alignment:talignment;;对齐方式 (5) top:integer;; 距纸张顶部距离 (6) Rowspace:integer;;行距 (7) EveryPage:boolean;;是否每页打印 二 、控件方法: (1) preview 预览 (2) print 打印 (3) SaveToFile() 保存为报表文件 (4) SaveToStream() 保存为流(然后就可把整个报表存到数据库了很方便哦! ~_~) (5) PrintFile() 打印报表文件 (6) PrintStream() 打印流(流的数据库存取就不用多说了吧) (7) PreviewFile() 预览文件 (8) PreviewStream() 预览流 (9) OptionToStream() 报表的属性保存为流 (10) OptionFromStream() 从流
中
得到报表属性 (11) OptionPost()在打印期间改变了报表属性,要想立即生效调用此方法。 (12) Paint
Text
(
Text
:string) 覆盖原有打印的字符,一般在能返回当前打印的内容的事件
中
使用。(见控件事件) 三、 控件事件: (1) AfterPrint 打印后 (2) BeforePrint 打印前 (3) OnPrintDetail(RecordNumber: Integer)在打印每一栏明细前触发此事件, 返回参数:RecordNumber返回当前打印行数。 (4) OnPrintDetailField(RecordNumber,FieldIndex: Integer;; Field
Text
: String);; 在打印明细的每个
字段
都会触发此事件。 返回参数:RecordNumber返回当前打印行数。 FieldIndex
字段
索引 Field
Text
字段
内容 (5) OnPrintTitle(Row: Integer;;
Text
: String)打印每行标题都会触发此事件。 返回参数:row当前打印的行
Text
当前打印的内容 (6) OnPrintColsTitleField(Row, FieldIndex: Integer;; FieldName: String);; 打印列标题
字段
时触发此事件 返回参数:row当前打印的行 FieldIndex当前打印的
字段
索引 FieldName当前打印的
字段
名称 (7) OnPrintColsTitle(Row: Integer) 打印每行列标题时触发此事件 返回参数:row当前打印的行 四、注意事项 (1)
text
属性,输入“¦#¦”打印页码值,如果想打印页码可输入“第¦#¦页” 输入“¦RecordCount¦”打印 记录数 (2) 不同的打印机,打印和预览效果可能有一点点不同(保证数据打印完全正确一致)。本人用一台针式和一台激光打印机做测试, 开始差别较大后经过调试基本一致,不知其他打印机如何。 (3) 纸张大小以及横向、竖向自动适应系统默认也可设置。 (4) 各列的宽度按比例,适应纸张宽度打印。 程序设计:吴进昊 E-mail :jinhaowu@hotmail.com qq :54254770 2003.01.03
怎样把
DB
Grid
的内容导出到Excel
void __fastcall TPhoneForm::SelectButtonClick(TObject *Sender) { AnsiString StrDate, ExName;//存放日期用于sheet AnsiString Datatem,phone1="拨号";//临时存放数据库的
字段
值 int i,j; //查询所需的数据 PhoneADOQuery->Close(); PhoneADOQuery->Parameters->ParamByName("date1")->Value=PhoneMaskEdit1->
Text
; PhoneADOQuery->Parameters->ParamByName("date2")->Value=PhoneMaskEdit2->
Text
; PhoneADOQuery->Active=true; //新建一个EXCEL Ex = Variant::CreateObject("Excel.Application"); Ex.OlePropertyGet("workbooks").OleFunction("Add", 6); Wb = Ex.OlePropertyGet("ActiveWorkBook"); Sh = Wb.OlePropertyGet("ActiveSheet"); Ex.OlePropertySet("Visible", true); //给sheet以日期重命名, StrDate=DateToStr(Date()); Sh.OlePropertySet("Name", StrDate.c_str()); //给EXCEL输入数据 for (j=0;j
FieldCount;j++) { Datatem=PhoneADOQuery->Fields->Fields[j]->FieldName; Sh.OlePropertyGet("Cells", 1, j+1).OlePropertySet("Value", Datatem.c_str()); } PhoneADOQuery->First(); for (i=0; i
RecordCount; i++) { for (j=0;j
FieldCount;j++) { Datatem=PhoneADOQuery->Fields->Fields[j]->AsString; Sh.OlePropertyGet("Cells", i+2, j+1).OlePropertySet("Value", Datatem.c_str()); if (phone1==PhoneADOQuery->Fields->Fields[j]->FieldName) {Sh.OlePropertyGet("Cells", i+2, j+1).OlePropertySet("NumberFormatLocal", "0_ ");//设置单元格格式为数值格式 } } PhoneADOQuery->Next(); } //保存EXCEL并退出 ExName=GetCurrentDir()+"\\"+DateToStr(Date())+".xls"; Wb.OleFunction("SaveAs", ExName.c_str()); Wb.OleFunction("Close"); Ex.OleFunction ("Quit"); Ex = Unassigned; }
RePrint 表格打印轻松做报表 打印datasource,
db
grid
,string
reprint 使用说明 直接从datasource,
db
grid
,string
grid
导入数据, 只需简单设置,不用手工制作,即可生成您需要的报表,具有预览功能。即可自定义纸张,又可适应 打印机默认纸张。各种打印设置,功能更强大。 一 、控件属性: 1、colstitle 设置报表的列标题属性 (1)alignment 列标题对齐方式。 (2)font 列标题字体 (3)print 设置是否打印列标题 (4)rowspace 列标题行的高度 2、datasource 选择要打印的datasource 3、
db
grid
选择要打印的
db
grid
4、string
grid
选择要打印的string
grid
5、detail 设置要打印的明细数据属性 (1)arrange 设置明细
字段
排列方向 Horizontal 横向打印(默认的一般打印) Vertical 竖向打印(
字段
竖向排列适合打印
字段
内容较长的报表如“会议纪录”) (2)aotureturn 打印明细
字段
时,如果
字段
超过列的宽度是否允许自动换行 (3)colsline 设置竖线属性引用tpen类 (4)footer 设置明细尾 (5)frame 设置明细边框属性引用tpen类 (6)head 设置明细头同footer (7)rowsline 设置横线属性引用tpen类 (8)rowspace 设置明细行的高度 (9)top 明细与标题的距离 6、page 设置纸张的上下左右边距 7、pagefooter 设置页脚同明细尾 8、pageheader 设置页眉同页脚 9、printobject 选择要打印的对象 (datasource 、
db
grid
、 string
grid
) 10、title 设置标题类页眉、页脚 二 、控件方法: (1) preview 预览 (2) print 打印 (3) SaveToFile() 保存为报表文件 (4) SaveToStream() 保存为流(然后就可把整个报表存到数据库了很方便哦! ~_~) (5) PrintFile() 打印报表文件 (6) PrintStream() 打印流(流的数据库存取就不用多说了吧) (7) PreviewFile() 预览文件 (8) PreviewStream() 预览流 (9) OptionToStream() 报表的属性保存为流 (10) OptionFromStream() 从流
中
得到报表属性 三、 控件事件: AfterPrint 打印后 BeforePrint 打印前 (本来很多事件,但没有预览,后来加上预览以及一些方法后实现很困难就去掉了!) 四、注意事项 (1)
text
属性,输入“¦;#¦;”打印页码值,如果想打印页码可输入“第¦;#¦;页” 输入¦;RecordCount¦;”打印记录数 (2) 不同的打印机,打印和预览效果可能有一点点不同(保证数据打印完全正确一致)。本人用一台针式和一台激光打印机做测试,开始差别较大后经过调试基本一致,不知其他打印机如何。 就这些个吧基本满足了我的软件开发需要,解决了很多问题,关键是做报表省了很大力气,当然了很复杂的报表还是要其它报表控件来解决。如果有其他问题或好的建议可与我联系。 程序设计:吴进昊 E-mail :jinhaowu@hotmail.com qq :54254770 2003.01.03 新增明细栏的左右对齐. 纸张类型、打印方向设置! 标题的每页打印设置。 列标题的每页,每行打印设置。 修改了打印时的错误!
Delphi
5,386
社区成员
262,729
社区内容
发帖
与我相关
我的任务
Delphi
Delphi 开发及应用
复制链接
扫一扫
分享
社区描述
Delphi 开发及应用
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章