1:打印dbgrid中的内容:
2:判断dbgrid中的某一列输入的东西前面7位是数值型的。
2:判断dbgrid中的某一列输入的东西前面7位是数值型的。
解决方案 »
- Delphi如何判断sql语句是查询语句还是执行语句
- 散分,今天挪位置了(二)
- 关闭客户端窗口出现Socket错误?
- 为什么delphi7中使用rave而不用自带的QReport
- 这其实是不是一个很简单的SQL语句?........
- 请问:如何取消QuickReport的打印???
- 怎样在程序中确定数据库中有没有某个表?(用ADOquery或其他)
- 两个变量计算再比较,用sql和delphi写要怎么样?
- 开发INTERNET———input 的程序,在服务器端用三层好还是直接连接的好?
- 欢迎进来!不会有错
- 请问:Raise 是干吗的?
- 如何修改TPreviewBox控件,他是Ehlib 3.2中的
2.建议别在dbgrid上输入,这样不好控制!
try
strtoint('取出的前7位');
showmessage('ok');
except
showmessage('no');
procedure TMainForm.printdbgrid(var datasource1: tdatasource;
var dbgrid1: tdbgrid);
const //定义页边距,单位厘米
LeftBlank=1;
RightBlank=1;
TopBlank=1;
BottomBlank=1;
var
PointX,PointY:integer;
PointScale,PrintStep:integer;
s:string;
x,y,i:integer;
begin
Application.MessageBox('打印开始','打印',32);
//获取当前打印机的分辨率
PointX:=Trunc(GetDeviceCaps(Printer.Handle,LOGPIXELSX)/2.54);
Pointy:=Trunc(GetDeviceCaps(Printer.Handle,LOGPIXELSY)/2.54);
//根据打印机和屏幕的分辨率计算出从屏幕转换到打印机的比例
PointScale:=Trunc(GetDeviceCaps(Printer.Handle,LOGPIXELSX)/Screen.PixelsPerInch+0.5);
//横向打印
printer.Orientation:=poLandscape;
//打印的字体和大小
printer.Canvas.Font.Name:='宋体';
printer.canvas.Font.Size:=10;
//根据字体的大小确定每行的高度
s:=combobox1.text;
PrintStep:=printer.canvas.TextHeight(s)+16;
//打印的起点位置
x:=PointX*LeftBlank;
y:=PointY*TopBlank;
//DataSource1是DBGrid1所连接的数据源
if ((DataSource1.DataSet).Active=true) and ((DataSource1.DataSet).RecordCount>0) then
begin
//(DataSource1.DataSet).DisableControls;
printer.BeginDoc;
//2002.50.28 新增 2句
printer.Canvas.TextOut(floor((printer.pagewidth)/2)-10,y,panel3.caption);
y:=y+printstep;
(DataSource1.DataSet).First;
while not (DataSource1.DataSet).Eof do
begin
//打印DBGrid中的所有列
for i:=0 to DBGrid1.FieldCount-1 do
begin
//假如所要打印的列超出了打印范围,则忽略该列
if (x+DBGrid1.Columns.Items[i].Width*PointScale)<=(Printer.PageWidth-PointX*RightBlank) then
begin //画表格线
//每页的第一行打印表头
Printer.Canvas.Rectangle(x,y,x+DBGrid1.Columns.Items[i].Width*PointScale,y+PrintStep);
if y=(PointY*TopBlank)+printstep then //2002.5.28新增printstep
Printer.Canvas.TextOut(x+8,y+8,DBGrid1.Columns[i].Title.Caption)
else
Printer.Canvas.TextOut(x+8,y+8,DBGrid1.Fields[i].asString);
end;
//计算下一列的横坐标
x:=x+DBGrid1.Columns.Items[i].Width*PointScale;
end;
if not (y=PointY*TopBlank) then
(DataSource1.DataSet).next;
x:=PointX*LeftBlank;
y:=y+PrintStep;
//换页
if (y+PrintStep)>(Printer.PageHeight-PointY*BottomBlank) then
begin
Printer.NewPage;
y:=PointY*TopBlank;
end;
end;
printer.EndDoc;
(DataSource1.DataSet).First;
(DataSource1.DataSet).EnableControls;
Application.MessageBox('打印完成','打印',32);
end;
end;