




已阅读5页,还剩26页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Delphi编程技巧集锦四川省攀枝花市第三高级中学 廖裕 编辑整理二四年十一月二十五日DELPHI网络邻居复制文件uses shellapi; copyfile(pchar(newfile.txt),pchar(/computername/direction/targer.txt),false); DELPHI产生鼠标拖动效果 通过MouseMove事件、DragOver事件、EndDrag事件实现,例如在PANEL上的LABEL: var xpanel,ypanel,xlabel,ylabel:integer; PANEL的MouseMove事件:xpanel:=x;ypanel:=y; PANEL的DragOver事件:xpanel:=x;ypanel:=y; LABEL的MouseMove事件:xlabel:=x;ylabel:=y; LABEL的EndDrag事件:label.left:=xpanel-xlabel;label.top:=ypanel-ylabel; DELPHI取得WINDOWS目录 uses shellapi; var windir:array0.255 of char; getwindowsdirectory(windir,sizeof(windir); 或者从注册表中读取,位置: HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersion SystemRoot键,取得如:C:WINDOWS DELPHI在FORM或其他容器上画线 var x,y:array 0.50 of integer; canvas.pen.color:=clred; canvas.pen.style:=psDash; form1.canvas.moveto(trunc(xi),trunc(yi); form1.canvas.lineto(trunc(xj),trunc(yj); DELPHI字符串列表使用 var tips:tstringlist; tips:=tstringlist.create; tips.loadfromfile(filename.txt); edit1.text:=tips0; tips.add(last line addition string); tips.insert(1,insert string at NO 2 line); tips.savetofile(newfile.txt); tips.free; DELPHI简单的剪贴板操作 richedit1.selectall; richedit1.copytoclipboard; richedit1.cuttoclipboard; edit1.pastefromclipboard; DELPHI关于文件、目录操作 Chdir(c:abcdir);转到目录 Mkdir(dirname);建立目录 Rmdir(dirname);删除目录 GetCurrentDir;/取当前目录名,无 Getdir(0,s);/取工作目录名s:=c:abcdir; Deletfile(abc.txt);/删除文件 Renamefile(old.txt,new.txt);/文件更名 ExtractFilename(filelistbox1.filename);/取文件名 ExtractFileExt(filelistbox1.filename);/取文件后缀 DELPHI处理文件属性 attr:=filegetattr(filelistbox1.filename); if (attr and faReadonly)=faReadonly then . /只读 if (attr and faSysfile)=faSysfile then . /系统 if (attr and faArchive)=faArchive then . /存档 if (attr and faHidden)=faHidden then . /隐藏 DELPHI执行程序外文件 WINEXEC/调用可执行文件 winexec( /c copy *.* c:,SW_Normal); winexec(start abc.txt); ShellExecute或ShellExecuteEx/启动文件关联程序 function executefile(const filename,params,defaultDir:string;showCmd:integer):THandle; ExecuteFile(C:abca.txt,x.abc,c:abc,0); ExecuteFile(,0); ExecuteFile(mailto:,0); DELPHI取得系统运行的进程名 var hCurrentWindow:HWnd;szText:array0.254 of char; begin hCurrentWindow:=Getwindow(handle,GW_HWndFrist); while hCurrentWindow 0 do begin if Getwindowtext(hcurrnetwindow,sztext,255)0 then listbox1.items.add(strpas(sztext); hCurrentWindow:=Getwindow(hCurrentwindow,GW_HWndNext); end; end; DELPHI关于汇编的嵌入 Asm End; 可以任意修改EAX、ECX、EDX;不能修改ESI、EDI、ESP、EBP、EBX。 DELPHI关于类型转换函数 FloatToStr/浮点转字符串 FloatToStrF/带格式的浮点转字符串 IntToHex/整数转16进制 TimeToStr DateToStr DateTimeToStr FmtStr/按指定格式输出字符串 FormatDateTime(YYYY-MM-DD,hh-mm-ss,DATE); DELPHI字符串的过程和函数 Insert(obj,target,pos);/字符串target插入在pos的位置。如插入结果大于target最大长度,多出字符将被截掉。如Pos在255以外,会产生运行错。例如,st:=Brian,则Insert(OK,st,2)会使st变为BrOKian。 Delete(st,pos,Num);/从st串中的pos(整型)位置开始删去个数为Num(整型)个字符的子字串。例如,st:=Brian,则Delete(st,3,2)将变为Brn。 Str(value,st);/将数值value(整型或实型)转换成字符串放在st中。例如,a=2.5E4时,则str(a:10,st)将使st的值为 25000。 Val(st,var,code);/把字符串表达式st转换为对应整型或实型数值,存放在var中。St必须是一个表示数值的字符串,并符合数值常数的规则。在转换过程中,如果没有检测出错误,变量code置为0,否则置为第一个出错字符的位置。例如,st:=25.4E3,x是一个实型变量,则val(st,x,code)将使X值为25400,code值为0。 Copy(st.pos.num);/返回st串中一个位置pos(整型)处开始的,含有num(整型)个字符的子串。如果pos大于st字符串的长度,那就会返回一个空串,如果pos在255以外,会引起运行错误。例如,st:=Brian,则Copy(st,2,2)返回ri。 Concat(st1,st2,st3,stn);/把所有自变量表示出的字符串按所给出的顺序连接起来,并返回连接后的值。如果结果的长度255,将产生运行错误。例如,st1:=Brian,st2:= ,st3:=Wilfred,则Concat(st1,st2,st3)返回Brian Wilfred。 Length(st);/返回字符串表达式st的长度。例如,st:=Brian,则Length(st)返回值为5。 Pos(obj,target);/返回字符串obj在目标字符串target的第一次出现的位置,如果target没有匹配的串,Pos函数的返回值为0。例如,target:=Brian Wilfred,则Pos(Wil,target)的返回值是7,Pos(hurbet,target)的返回值是0。 DELPHI关于处理注册表 uses Registry; var reg:Tregistry; reg:=Tregistry.create; reg.rootkey:=HKey_Current_User; reg.openkey(Control PanelDesktop,false); reg.WriteString(Title Wallpaper,0); reg.writeString(Wallpaper,filelistbox1.filename); reg.closereg; reg.free; DELPHI关于键盘常量名 VK_BACK/VK_TAB/VK_RETURN/VK_SHIFT/VK_CONTROL/VK_MENU/VK_PAUSE/VK_ESCAPE /VK_SPACE/VK_LEFT/VK_RIGHT/VK_UP/VK_DOWN F1-F12:$70(112)-$7B(123) A-Z:$41(65)-$5A(90) 0-9:$30(48)-$39(57) DELPHI初步判断程序母语 DELPHI软件的DOS提示:This Program Must Be Run Under Win32. VC+软件的DOS提示:This Program Cannot Be Run In DOS Mode. DELPHI操作Cookie response.cookies(name).domain:=; with response.cookies.add do begin name:=username; value:=username; end DELPHI增加到文档菜单连接 uses shellapi,shlOBJ; shAddToRecentDocs(shArd_path,pchar(filepath);/增加连接 shAddToRecentDocs(shArd_path,nil);/清空 杂类备份智能ABC输入法词库 windowssystemuser.rem windowssystemtmmr.rem DELPHI判断鼠标按键 if GetAsyncKeyState(VK_LButton)0 then . /左键 if GetAsyncKeyState(VK_MButton)0 then . /中键 if GetAsyncKeyState(VK_RButton)0 then . /右键 DELPHI设置窗体的最大显示 onFormCreate事件 self.width:=screen.width; self.height:=screen.height; DELPHI按键接受消息 OnCreate事件中处理:Application.OnMessage:=MyOnMessage; procedure TForm1.MyOnMessage(var MSG:TMSG;var Handle:Boolean); begin if msg.message=256 then . /ANY键 if msg.message=112 then . /F1 if msg.message=113 then . /F2 end; 杂类隐藏共享文件夹 共享效果:可访问,但不可见(在资源管理、网络邻居中) 取共享名为:direction$ 访问:/computer/dirction/ Java ScriptJava Script网页常用效果 网页60秒定时关闭 关闭窗口 关闭 定时转URL 设为首页 设为首页 收藏本站 收藏本站 加入频道 加入频道 DELPHI文本编辑相关 checkbox1.checked:=not checkbox1.checked; if checkbox1.checked then richedit1.font.style:=richedit1.font.style+fsBold else richedit1.font.style:=richedit1.font.style-fsBold/粗体 if checkbox1.checked then richedit1.font.style:=richedit1.font.style+fsItalic else richedit1.font.style:=richedit1.font.style-fsItalic/斜体 if checkbox1.checked then richedit1.font.style:=richedit1.font.style+fsUnderline else richedit1.font.style:=richedit1.font.style-fsUnderline/下划线 memo1.alignment:=taLeftJustify;/居左 memo1.alignment:=taRightJustify;/居右 memo1.alignment:=taCenter;/居中 DELPHI随机产生文本色 randomize;/随机种子 memo1.font.color:=rgb(random(255),random(255),random(255); DELPHIDELPHI5 UPDATE升级补丁序列号 1000003185 90X25fx0 DELPHI文件名的非法字符过滤 for i:=1 to length(s) do if si in ,/,:,*,?,| then DELPHI转换函数的定义及说明 datetimetofiledate (datetime:Tdatetime):longint; 将Tdatetime格式的日期时间值转换成DOS格式的日期时间值 datetimetostr (datetime:Tdatetime):string; 将Tdatatime格式变量转换成字符串,如果datetime参数不包含日期值,返回字符串日期显示成为00/00/00,如果datetime参数中没有时间值,返回字符串中的时间部分显示成为00:00:00 AM datetimetostring (var result string; const format:string; datetime:Tdatetime); 根据给定的格式字符串转换时间和日期值,result为结果字符串,format为转换格式字符串,datetime为日期时间值 datetostr (date:Tdatetime) 使用shortdateformat全局变量定义的格式字符串将date参数转换成对应的字符串 floattodecimal (var result:Tfloatrec;value: extended;precision,decimals: integer); 将浮点数转换成十进制表示 floattostr (value:extended):string 将浮点数value转换成字符串格式,该转换使用普通数字格式,转换的有效位数为15位。 floattotext (buffer:pchar;value:extended; format:Tfloatformat;precision, digits:integer):integer; 用给定的格式、精度和小数将浮点值value转换成十进制表示形式,转换结果存放于buffer参数中,函数返回值为存储到buffer中的字符位数,buffer是非0结果的字符串缓冲区。 floattotextfmt (buffer:pchar;value:extended; format:pchar):integer 用给定的格式将浮点值value转换成十进制表示形式,转换结果存放于buffer参数中,函数返回值为存储到buffer中的字符位数。 inttohex (value:longint;digits:integer): string; 将给定的数值value转换成十六进制的字符串。参数digits给出转换结果字符串包含的数字位数。 inttostr (value:longint):string 将整数转换成十进制形式字符串 strtodate (const S:string):Tdatetime 将字符串转换成日期值,S必须包含一个合法的格式日期的字符串。 strtodatetime (const S:string):Tdatetime 将字符串S转换成日期时间格式,S必须具有MM/DD/YY HH:MM:SSAM|PM格式,其中日期和时间分隔符与系统时期时间常量设置相关。如果没有指定AM或PM信息,表示使用24小时制。 strtofloat (const S:string):extended; 将给定的字符串转换成浮点数,字符串具有如下格式: +|-nnn.nnnnnnn strtoint (const S:string):longint 将数字字符串转换成整数,字符串可以是十进制或十六进制格式,如果字符串不是一个合法的数字字符串,系统发生ECONVERTERROR异常 strtointdef (const S:string;default: longint):longint; 将字符串S转换成数字,如果不能将S转换成数字,strtointdef函数返回参数default的值。 strtotime (const S:string):Tdatetime 将字符串S转换成TDATETIME值,S具有HH:MM:SSAM|PM格式,实际的格式与系统的时间相关的全局变量有关。 timetostr (time:Tdatetime):string; 将参数TIME转换成字符串。转换结果字符串的格式与系统的时间相关常量的设置有关。 DELPHI程序不出现在ALT+CTRL+DEL 在implementation后添加声明: function RegisterServiceProcess(dwProcessID, dwType: Integer): Integer; stdcall; external KERNEL32.DLL; RegisterServiceProcess(GetCurrentProcessID, 1);/隐藏 RegisterServiceProcess(GetCurrentProcessID, 0);/显示 用ALT+DEL+CTRL看不见 DELPHI程序不出现在任务栏 uses windows var ExtendedStyle : Integer; begin Application.Initialize;Delphi中延时的程序procedure Delay(msecs:integer);varFirstTickCount:longint;beginFirstTickCount:=GetTickCount;repeatApplication.ProcessMessages;until (GetTickCount-FirstTickCount) = Longint(msecs);end;在DELPHI中使用ADO直接访问Excel数据文件承蒙各位大鱼大虾的支持,终于顿悟。现在将心经写下来,让后来者提高修成正果的效率,早日成为大鱼大虾。要用DELPHI中的ADO系列控件访问Excel数据文件,首先应该建立一些基本概念。你需要将一个Excel数据文件想象为一个关系数据库,Excel文件中的每个工作表就对应该数据库中的一个表,而工作表中的每一列当然就是表的列了。然后,按照下列面的秘诀进行就可以。1.设置ADOConnection的ConnectionString 构造ConnectionString时,OLE DB的提供者要选择Microsoft Jet 4.0 OLE DB Provider作为ADO的驱动程序。这本来是用于连接Access数据库的驱动程序,但也可打开Excel文件。 连接的数据库名称当然就是你要打开的Excel文件,注意扩展名是*.xls,而不是*.mdb。 最关键的一点是,还要设置扩展属性Extended Properties为“Excel 8.0”,否则,测试连接时会报告无法识别数据格式的错误。Extended Properties的属性值在“所有”参数页中输入。 最后,设置完成后的ConnectionString中的各项参数为: Provider=Microsoft.Jet.OLEDB.4.0 Data Source=MyExcelFile.xls Extended Properties=Excel 8.0 Persist Security Info=False2.设置ADODataSet或ADOTable 将ADODataSet或ADOTable连接到刚才的ADOConnection。如果不用ADOConnection,也可以参照上面的方法直接设置ADODataSet或ADOTable的ConnectionString属性。 对于ADODataSet,需要将CommandType属性设置为cmdTableDirect,而对于ADOTable,则将TableDirect属性设置为True。因为,访问Excel文件是直接的数据文件访问,不是通过SQL语句来操作游标访问的。如果不设置直接访问,则系统会报告SQL语句格式错误等信息。 然后,当你下拉ADODataSet中的CommandText属性或ADOTable的TableName属性时,就可以选择到要打开的工作表了。注意,表名后面多了加一个$符号。3.打开ADODataSet或ADOTable用Delphi编程访问SQLServer数据库Delphi是一个优秀的可视化软件开发环境,并已广泛应用于数据库软件的开发。在DelphiCS版环境中,结合其优化的数据库操作,以及Borland Database Engine(即:BDE,数据库引擎),对开发客户机服务器系统下的网络数据库软件提供了更加快速有效的途径。在客户机服务器系统中,服务器端我们采用Microsoft SQL Server60 for WindowsNT作为数据库服务器;另外,在客户端采用Delphi编写客户软件。在此,我们假定SQLServer设置完毕,并已经启动,仅介绍客户端的程序编写步骤。从以下文章中,读者可以发现不需要写一句程序,就能实现对SQL Server数据库的操作了。具体步骤如下: 第一步,注册ODBC数据源。这是至关重要的一步,否则就无法实现对数据库的访问。例如,我们定义一个可访问SQL Server服务器上zhb数据库的数据源ZHB。首先,选择SQL Server类型的数据库,进入ODBC SQL Server Setup窗口。然后,定义数据源名称为ZHB;定义Server为SQL-Server;以及网络路径为SQL-Server;最后,按option命令按钮选择访问的数据库为zhb即可。第二步,配置BDE。它是Delphi专用的数据库引擎。既可以从Delphi程序组里启动,也可以从Delphi程序项的Tools菜单下启动。Delphi在访问SQL Server数据库时略不同于VB。VB是直接调用ODBC来连接SQLServer的,而Delphi是首先调用BDE中的别名,别名再通过BDE中的ODBC Driver直接访问ODBC数据源实现的。而在BDE的ODBC Driver中你还可以定义其他ODBC属性,例如语言驱动程序或打开模式等等。这无疑大大增强了ODBC的功能。首先,在Drivers标记页中,按New ODBC Driver添加新的驱动程序。在添加窗口中有三栏需要填写。第一栏SQL Link Driver可任取一名,如:ODBC-ZHB;第二栏Default ODBC Driver中选择SQL Server;在第三栏default Data Source Name中选择刚才注册的数据源ZHB。按OK确认后就增加了一个名为ODBC-ZHB的DelphiODBC驱动程序。在其右侧的参数表中,还可以设置打开模式OPENMODE、查询模式SQLQRYMODE、SQL语句执行模式SQLPASSTHRUMODE以及语言驱动程序LANGDRIVER等。接下来,在Aliases标记页中,按NewAlias命令按钮增加一个新的别名。在增加新别名窗口中有两栏需要填写。第一栏为Newaliasname,可任取一个名字,如:zhbdb;这个别名就是我们要在Table控件中直接调用的数据库名字。第二栏Aliastype选择刚才在Drivers标记页中定义的ODBC-ZHB,最后按OK确认,就增加了一个名为zhbdb的别名。这样,Table控件可以通过别名zhbdb,别名zhbdb通过Delphi的ODBCDrivers(即:ODBC-ZHB),ODBC-ZHB再通过ODBC数据源ZHB就可连接到SQL-Server服务器上的zhb数据库了。以上相当于完成了在BDE中的注册,接下来就可以进行控件的属性设置了。第三步,设置Data Access控件属性以实现与数据库的连接。将Table和DataSource控件加到窗体中并修改Table控件的属性。首先,将DatabaseName属性改为刚才在BDE别名中定义的zhbdb。设置完databaseName属性后,就可以从TableName属性的下拉列表中选择一个表的名字。这其间Table控件要完成与数据库的连接,连接成功后,该列表中才会出现可选的表名。然后,将Active属性改为true,将打开的数据库激活,和DataSource控件建立联系。将Exclusive属性改为true。最后,将DataSource控件的DataSet属性设为Table1。DataSource控件为Table控件与DataControls控件相联系的渠道。通过以上步骤的设置,DataSource1对象就与zhb数据库的某个表建立了联系。以后,只要对DataSource1对象访问,就可以实现对该表的操作了。第四步,设置Data Controls控件属性以实现对数据库的操作。一旦Data Access类的控件被成功打开,处于窗口中的Data Controls标记页的控件就可以使用了。这些控件有DBGrid、DBNavigator、DBText、DBEdit、DBMemo、DBImage、DBListBox、DBComboBox、DBCheckBox以及DBRadioGroup。这些控件只要设定他们的DataSource和DataFields属性就可以实现对表的读写操作。可以看出,Delphi在设计数据库软件方面,尤其是SQLServer数据库方面要比VB来得快;而且,其丰富的控件为界面的设计提供了有利帮助;另外,Delphi的真编译使程序的执行效率相当高,可移植性好。这些,都是VB所欠缺的。DELPHI存取JPEG文件到SQL Server数据库近日笔者书写一个小型的学生管理系统时,需要用到ADO控件存取SQL Server数据库图片,查看资料发现基本都是针对BMP文件进行操作(巨增数据库大小),但发现了eagletian高手翻译的ADO英文技术文档,里面涉及到了数据库存取JPEG文件的关键技术,在win98+sql server桌面版中测试通过,运行良好,现于源码公开如下:unit Unit1;interfaceusesWindows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,ExtCtrls, DBCtrls, Grids, DBGrids, Db, ADODB,jpeg, StdCtrls,dbtables;一定要USES JPEG单元,使能存储JPG文件格式typeTForm1 = class(TForm) DataSource1: TDataSource; ADOQuery1: TADOQuery; DBGrid1: TDBGrid; DBNavigator1: TDBNavigator; Image1: TImage; savebutton: TButton; showbutton: TButton; OpenDialog1: TOpenDialog; ADOQuery1id: TIntegerField; ADOQuery1pic: TBlobField; procedure savebuttonClick(Sender: TObject); procedure showbuttonClick(Sender: TObject); procedure DBNavigator1Click(Sender: TObject; Button: TNavigateBtn);private Private declarations public Public declarations end;varForm1: TForm1;implementation$R *.DFMfunction JpegStartsInBlob(PicField:TBlobField):integer;var ghy: TADOBlobstream; buffer:Word; hx: string;begin Result := -1; ghy := TADOBlobstream.Create(PicField, bmRead); trywhile (Result = -1) and (ghy.Position + 1 ghy.Size) dobegin ghy.ReadBuffer(buffer, 1); hx:=IntToHex(buffer, 2); if hx = FF then beginghy.ReadBuffer(buffer, 1);hx:=IntToHex(buffer, 2); if hx = D8 then Result := ghy.Position - 2else if hx = FF thenghy.Position := ghy.Position-1; end; /ifend; /whilefinally ghy.Freeend;/tryend;procedure TForm1.savebuttonClick(Sender: TObject);varpicstream:tadoblobstream;beginadoquery1.edit;picstream:=tadoblobstream.Create(tblobfield(adoquery1.fields1),bmWrite);if form1.opendialog1.execute thenbeginpicstream.LoadFromFile(opendialog1.filename);picstream.Position:=0;adoquery1.edit;tblobfield(adoquery1.Fields1).loadfromstream(picstream);adoquery1.post;end;end;procedure TForm1.showbuttonClick(Sender: TObject);varghy:TADOBlobs
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 农业物联网设备的创新与应用-洞察及研究
- 游戏化营销策略分析-洞察及研究
- 稳定靶向纳米胶束构建-洞察及研究
- 手指画培训课件
- 科技部合同范本D007-技术咨询合同6篇
- 人教版四年级数学上学期第1单元大数的认识综合素养评价卷(含答案)
- 湖南省娄底市涟源市2024-2025学年七年级下学期期末道德与法治试题(含答案)
- 混沌态热力学分析-洞察及研究
- 手卫生指征培训课件
- 学生法制安全教育培训课件
- 脑电图基础知识及判读课件
- 病毒性脑炎临床路径(2016年版)
- 装修公司审计报告范本
- IATF16949项目移交管理程序
- 第三节酒店业的演变-课件
- GB/T 8758-2006砷化镓外延层厚度红外干涉测量方法
- GB/T 6396-2008复合钢板力学及工艺性能试验方法
- GB/T 35759-2017金属清洗剂
- ABB缠绕型干式变压器
- GB/T 21063.1-2007政务信息资源目录体系第1部分:总体框架
- 第三讲:新闻真实性分析课件
评论
0/150
提交评论