工程图纸中经常遇到大量表格填写,例如工程勘察中的成果表、设计的材料表,在AutoCAD中文字处理比较差,用TEXT、DTEXT命令在表格中定位也不方便,填写的表格既不美观,还容易出错。在一些杂志中有关表格填写程序介绍,但是使用不方便,也不能连续填写多个表格,长距离线路勘察中线转点少则几十个,多则上千,中线数据可由计算直接生成,能否利用中线数据直接填表出图。利用AutoCAD二次开发,编写中线成果填写程序(zxcg.lsp),改变以往出图工序(填写、校对),大大提高工作效率。   

一、程序功能与编写说明


  1、本程序具有下列功能:


  (1)直接在文本编辑器(EDIT、QE、WPS等等)编辑 、修改数据,免去AutoCAD文字编辑、修改之不便;


  (2)可以自动分页,自动填写工程名称、档案号、日期等等;


  (3)可以自动处理中线成果数据前后的空格,例如 :“123123.123”将自动转化为“123123.23”;


  (4)可以自动识别两种工程名称数据文件;

  (5)文本状态下数据正确无误,出图前无需在Auto CAD中修改,调图速度和重新成图速度相差无几,可直接保存数据文件,节省磁盘空间。


  2、程序说明:


  程序利用AutoLISP的计算、判断、字符处理、循环结构以及调用Text命令等功能对读入的数据进行处理后填写,与本程序对应的Zxcg.dwg图形文件含四个表格图块,程序中的有关参数均取决于四个图块。  

二、使用说明


  1、关于中线成果数据格式:


  (1)无曲线


  第一行,总点数(N)


  第二至七行,点名(NAME)、里程(K)、高程(H)、坐标X、Y、转角(B)……重复二至七行(没有数据项用空行代替)


  (2)有曲线


  第一行,总点数(N)


  第二至十一行,点名(NAME)、里程(K)、高程(H)、坐标X、Y、转角B,半径R,切线长T、曲线长L、外矢矩E   ……重复二至十一行(没有数据项用空行代替)


  2、关于工程名称数据格式:


  (1)单标题


  第一行,工程名称


  第二行,档案号(如测-3777/表,只需输入3777)

 

  第三行,日期(可省略,取当前日期)


  (2)双标题


  第一行,工程名称大标题


  第二行,工程名称小标题


  第三行,档案号(如测-3777/表,只需输入3777)

 

  第四行,日期(可省略,取当前日期)


  

三、加载及运行


  在AutoCADR12(或AutoCADforWindows)中,把Zxcg .lsp和Zxcg.dwg拷贝到SUPPORT子目录下,用鼠标点文件(File)下应用程序(Applications),或在Command :下敲入Appload加载Zxcg.lsp,或在Command:下敲入(Load“Zxcg”)即可。然后在Command:下敲入ZX运行程序,本程序将中文提示。


四、结束语


  该应用程序提供了两种形式的表格,有兴趣的Auto CAD用户不妨增加几种表格,修改程序中对应的参数即可。


  附源程序


  ...****ERROR****


  (DEFUNERR(X);IFANERROR(SUCHASCTRL-C)


  OCCURS ;WHILETHISCOMMANDISACTIVE


  (IF(AND(/ΚX″FUNCTIONCANCELLED ″)


  (/ΚX″QUIT/EXITABORT″))


  (PPINC(STRCAT″ιnERROR:″X)))


  (SETVAR″CMDECHO″1)(SETVER″BLIPMODE″1)


  (IF(ΚTYPERF)′FILE)(CLOSERF))


  (IF(ΚTYPERN)′FILE)(CLOSERN))


  (SETQRFNIL)(SETQRNNIL)


  (SETQ*ERROR*OLDERR);RESTOREOLD*ERROR*HANDLER


  (PRINC))


  ...****FILETOREAD****


  (DEFUNINPUT()


  (IF(ΚFF1nil)(SEFQFF1(GETVAR″DWGPREFIX″)))
  (SETQF1(GETFILED″请输入中线成果数据文件″FF1″DAT″12))


  (SETQLF(STRLENF1)FF1(SUBSTRF11(-LF4)))


  (IF(ΚFF2nil)(SETQFF2FF1))


  (SETQF2(GETFILED″请输入工程名称文件″FF2″TXT″12))


  (SETQLF(STRLENF2)FF2(SUBSTRF21(-LF4)))


  (initget″YesNo″)


  (setqYN(getkword″ιn请选择有曲线元素Yes/No:(N)″))


  (if(ΚYNnil)(SETQYN″No″)))


  ...****DATAFORPROGRAMME*****


  (DEFUNDDAT()


  (SETQRF(OPENF1″r″))(SETQRN(OPENF2″r″))


  (SETQGN(READ-LINERN)GG1DAH(READ-LINERN))


  (IF(ΚATOIDAH)0)(PROGN(SETQGG2GN2DAHDAH(READ-LINERN))))


  (SETQDAT(READ-LINERN))


  (IF(ΚDATNIL)(PROGN(SETQDAT(GETVAR″CDATE″));取当前日期


  (SETQDAT(FIXDAT))(SETQDAT(ITOADAT))


  (SETQYY(SUBSTRDAT14)MM(SUBSTRDAT52))


  (SETQDD(SUBSTRDAT72)DAT(STRCATYY″-″MM″-″DD))))


  (SETQNO(READ-LINERF)N(ATOINO))


  (SETQNF26NN29);首、次页行数


  (SETQM(FIX(+(/(-NNF)NN)2))):计算页数


  (SETQNL(REM(-NNF)NN))(IF(ΚNL0)(SETQM(-M1)NLNN))


  (IF(ΙΚNNF)PROGN(SETQM1)(SETQNLN)))


  (princ″共读入″)(PRINCN)(PRINC″点,分″)(PRINCM)(PRINC″页填写!″)


  (SETQYY8XX230);行距、页距


  (SETQI1X00Y00DAH(STRCAT″测-″DAH″/″))

 

  (IF(ΚYN″NO″)(SETQDI(LIST678.58103.58125.08150.08180.08208.08))


  (SETQDI(LIST1071.9088.39105.58122.61140.30156.83172.86188.07208.00232.))))


  ;表格项数及各项横坐标(X)


  (SETQYYF285.0YYN305.7);首、次页第一行纵坐标


  ....****删除数据前后空格(QKG)******


  (DEFUNQKG()


  (SETQLE1)


  (WHILE(〈LE(STRLENTXT))(RPOGN(SETQLF(+1LE))


  (WHILE(Κ(SUBSTRTXT11)″″)(PROGN (SETQTXT(SUBSTRTXT2(STRLENTXT)))))))

 

  (SETQLE(STRLENTXT))


  (IF(〉LE2)(WHILE(AND(Κ(SUBSTRTXTLE1)″″)(ΛLE2))


  (PROGN(SETQLE(-LE1)TXT(SUBSTRTXT1LE))))))


  .....*****ZXTX******


  (DEFUNZXTX()


  (PRINC″ιn正在填写中线成果数据,请稍候!″)

 

  (WHILE(ΙΚIM)(PROGN(SETQPT0(LISTX0Y0))


  (SETQP1(LIST(+X0236.0)348.5))(SETQP2 (LIST(+X0207.0)342.0))


  (SETQP3(LIST(+X0227.0)342.0))(SETQP4(LIST(+X0222.2)335.6))


  (IF(ΚYN″No″)(IF(ΚI1)(SETQZX″*PZX-F″)(SETQZX″*PZX-N″));图块选择


  (IF(ΚI1)(SETQZX″*QZX-F″)(SETQZX″*QZX-N″)))


  (COMMAND″INSERT″ZXPT0″1″″0″)


  (IF(ΚI1)(PROGN(SETQP2(LIST(+X0207.0)336.0))


  (SETQP3(LIST(+X0227.0)336.0))(SETQP4 (LIST(+X0222.2)329.6))


  (SETQP5(LIST(+X0125.1)329.5))(SETQP6(LIST(+X0185.9)329.5))

 


  (IF(ΚGG2)(PROGN(SETQP5(LIST(+X0125.1 )333.5))


  (SETQP6(LIST(+X0185.9)333.5))(SETQP7 (LIST(+X0135.1)323.5))


  (SETQP8(LIST(+X0175.9)323.5))))


  (COMMAND″TEXT″″S″″HZ″″J″″A″P5P6GN)

 

  (COMMAND″TEXT″″J″″M″P4″2.5″″0″DAT )


  (IF(ΚGG2)(COMMAND)″TEXT″″J″″A″P7P8 GNZ))))


  (IF(ΚI1)(SETQJNF)(SETQJNN))