(defun c:thzf (/ ylword thword sstext xxcs thtext thqm thstring qszf yllong newstring thwz) (command "undo" "be") (setq ylword (getstring "请输入原字符:")) (setq thword (getstring "请输入目标字符:")) (if (=thword "d9=650") (setq thword "d9=450") ) (setq sstex (ssget)) (setq xxcs 0) (repeat (sslength sstex) (setq thtext (ssname sstext xxcs)) (setq thqm (entget thtext)) (if (or (= (cdr (assoc 0 thgm)) "MTEXT") (= (cdr (assoc 0 thqm)) "TEXT") ) (progn (setq thstring (cdr (assoc 1 thqm))) (setq qszf 1) (setq yllong (strlen ylword)) (setq newstring "") (while (<= qszf (strlen thstring)) (setq thwz (substr thstring qszf yllong)) (if(=thwz ylword) (progn (setq thwz thword) (setq newstring (strcat newstring thwz)) (setq qszf (+ qszf yllong)) ) (progn (setq newstring (strcat newstring (substr thstring qszf 1)) ) (setq qszf (+qszf 1)) ) ) ) (setq thqm (subst (cons 1 newstring)(assor 1 thqm) thqm)) (entdel thtext) (entmake thqm) (setq xxcs (+ xxcs 1)) ) ) ) (command "undo" "e") (prin1) )这个CAD与EXCEL交换数据的程序哪里不对
时间: 2024-04-27 13:20:55 浏览: 106
这个程序看起来有几个问题:
1. 第一行的变量名 "ylword" 和 "thword" 可能会与程序中已有的变量名冲突,应该考虑更具有描述性的变量名。
2. 第二个 if 语句中的比较操作符应该是 "=" 而不是 "=="。
3. 第 9 行中的变量名 "sstex" 应该是 "sstext"。
4. 第 11 行中的变量名 "xxcs" 应该初始化为 0。
5. 第 12 行中的变量名 "sstext" 应该改成 "sstex"。
6. 第 15 行中的变量名 "thtext" 应该改成 "thgm"。
7. 第 25 行中的变量名 "qszf" 应该改成 "i"。
8. 第 37 行中的变量名 "qszf" 应该改成 "i"。
9. 第 41 行中的变量名 "thwz" 应该改成 "subtext"。
10. 第 54 行中的变量名 "qszf" 应该改成 "(+ i yllong)"。
11. 第 61 行中的变量名 "qszf" 应该改成 "(+ i 1)"。
12. 第 64 行中 "assor" 应该是 "assoc"。
13. 第 66 行中的变量名 "xxcs" 应该改成 "(1+ xxcs)"。
14. 第 72 行中的 "prin1" 应该改成 "(princ)"。
总的来说,这个程序需要进行一些小的修改才能正确运行。
相关问题
(DEFUN RESPONSE_ACTION( DD DAYS0921 ABSOLUTETIME0921 / BKEY LOOP ) (setq LOOP T) (while (and LOOP ) (COND ((= 10 DD ) (ALERT "试用有时长限制,先看视频再操作,超过时长,插件会自动损毁。请根据B站视频操作\nhttps://space.bilibili.com/1226009502\n如果遇到问题,请联系淘宝店铺【画图神器】提供免费技术支持\n如果插件满足您的需求,请购买正版支持一下,谢谢。" ) (PRINC "\nhttps://space.bilibili.com/1226009502" ) (if (NULL (TIMECHECK DAYS0921 ABSOLUTETIME0921 ) ) (PROGN (ALERT "\n试用时间到,如果插件满足您的需求,请联系淘宝【店铺】画图神器购买正版支持一下,谢谢。" ) (PRINC "\n试用时间到,如果插件满足您的需求,请联系淘宝【店铺】画图神器购买正版支持一下,谢谢。" ) (setq DD (POPUP_INTERFACE )) )(PROGN (vlax-ldata-put "CZL" "USERKEY" (setq BKEY "iq27p0j") ) (VL-REGISTRY-WRITE ADRRESREGESTER "key" BKEY ) (setq LOOP nil) )) ) ((OR (= 1 DD ) (= 11 DD ) ) (setq BKEY (NTH 1 VALUE0919 )) (if (OR (NULL BKEY ) (WCMATCH BKEY ",* *,*画图神器*" ) ) (PROGN (setq BKEY "函数出错") )) (vlax-ldata-put "CZL" "USERKEY" BKEY ) (VL-REGISTRY-WRITE ADRRESREGESTER "key" BKEY ) (if (/= BKEY (vlax-ldata-get "CZL" "KEY" ) ) (PROGN (ALERT "\n密码错误,如有疑问,欢迎联系淘宝【店铺】画图神器。" ) (PRINC "\n密码错误,如有疑问,欢迎联系淘宝【店铺】画图神器。" ) (setq DD (POPUP_INTERFACE )) )(PROGN (ALERT "\n密码正确1\n" ) (PRINC "\n密码正确1,激活成功!\n" ) (setq LOOP nil) )) (PRINC ) ) ((= 0 DD ) (PRINC "\n已取消,如有疑问,欢迎联系淘宝【店铺】画图神器。" ) (EXIT ) ) ((= 100 DD ) (PRINC "\n操作视频" ) (PRINC "\n如果浏览器无响应,可手动前往:\nhttps://space.bilibili.com/1226009502\n******" ) (startapp "explorer.exe" "https://space.bilibili.com/1226009502" ) (setq DD (POPUP_INTERFACE )) ) ) ) )
这段代码是一个LISP函数,名为RESPONSE_ACTION。它接受四个参数:DD, DAYS0921, ABSOLUTETIME0921和BKEY。函数的主要功能是根据不同的条件进行不同的操作。
首先,函数会将变量LOOP设为真。然后,使用while循环来检查LOOP的状态。
在循环中,通过COND语句对DD的值进行判断。如果DD等于10,会弹出一个警告窗口并显示一条消息,然后打开一个B站视频。在视频结束之前,如果超过了设定的时间限制,插件会自动损坏。
如果DD的值等于1或11,函数会获取VALUE0919列表的第一个元素,并将其赋给BKEY。然后,检查BKEY是否为空或是否匹配特定的字符串。如果BKEY为空或匹配特定字符串,将BKEY设为"函数出错"。
接下来,函数将BKEY存储到LISP数据区,并将其写入注册表中的地址寄存器。如果BKEY和LISP数据区中存储的"KEY"值不相等,会弹出一个警告窗口并显示一条消息,然后重新弹出一个用户界面以获取新的DD值。
如果BKEY和LISP数据区中存储的"KEY"值相等,会弹出一条消息表示密码正确,并将LOOP设为假,终止循环。
如果DD的值等于0,会显示一条消息表示已取消操作,并退出函数。
如果DD的值等于100,会显示一条消息表示操作视频,并打开一个网址链接。
以上就是RESPONSE_ACTION函数的主要流程。
(defun angf (alf) (setq alff (angtos alf 1 4) n 1 kk (strlen alff)) (repeat kk (setq alfn (substr alff n 1)) (if (= alfn "d") (setq nn n));if (setq n (+ n 1)) );repeat (strcat (substr alff 1 (- nn 1)) "%%" (substr alff nn)) );angf (defun c:hh(/ p1 p2 pt1 pt2 pt3 pt4 pt5 pt6 pt10 pt20 id__ R V Ls E p3 r1 x y l x0 x1 C jd alf alf1 alf2 q p Cl Ls1 Ls2) (command "ucs" "") (setq p1 nil p2 nil) (while (= p1 nil) (setq p1 (entsel "\n拾取第一条直线:"))) (redraw (car p1) 3) (while (= p2 nil) (setq p2 (entsel "\n拾取第二条直线:"))) (redraw (car p2) 3) (initget 1) (setq R (getdist "\n请输入弯道半径 R: ")) (initget 1 "Ls V") (setq p3 (getdist "\n输入缓和曲线长度(Ls)或[设计速度(V)]: ")) (if (= p3 "V") (ll_v) (progn (setq ls p3) (ll_d))) (princ) );eline
这段代码是一个AutoLISP程序的一部分。其中包含了两个函数:angf和c:hh。
首先是angf函数,它用于格式化角度值。在函数中,将输入的角度值转换为字符串,并通过循环遍历每个字符。如果遇到字符"d",则将当前位置n保存在变量nn中。最后,将字符串分割为两部分,并在它们之间添加"%%",然后返回结果。
接下来是c:hh函数,它是整个程序的入口函数。在函数中,首先重置UCS坐标系。然后,通过entsel函数分别选择两条直线,并使用redraw函数将它们绘制出来。接着,使用getdist函数获取弯道半径R的值。然后,通过initget和getdist函数获取缓和曲线长度Ls或设计速度V的值,并根据用户的选择调用ll_v或ll_d函数进行计算。最后,使用princ函数打印输出结果。
整个代码段的目的是在AutoCAD中绘制缓和曲线。根据用户选择的直线和输入的参数值,计算出相应的长度和角度,并进行绘制操作。
阅读全文