找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 5876|回复: 19

[分享]:给选定的一组数字统一加上或减去一个数值

[复制链接]

已领礼包: 39个

财富等级: 招财进宝

发表于 2003-1-5 14:18:47 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
  1. [font=courier new]
  2. (defun C:NUM ()
  3. (setq ss1 (ssget)
  4.       len1 (sslength ss1)
  5.       cnt 0
  6.       add (getreal "\nEnter number to add to elevations:  ")
  7.       )
  8. (while (< cnt len1)
  9.   (setq dent (entget (ssname ss1 cnt))
  10.         txt (cdr (assoc 1 dent))
  11.         len (strlen txt)
  12.         cnt1 1
  13.         )
  14.    (while (<= cnt1 len)
  15.     (if (/= (substr txt cnt1 1) " ")
  16.      (progn
  17.       (setq num (atof (substr txt cnt1 len))
  18.             numlen (strlen (rtos num 2 5)))
  19.        (if (/= num 0)
  20.          (progn   
  21.           (cond ((= (substr txt cnt1 numlen) (rtos num 2 5)) (setq sp 0))
  22.                 ((= (substr txt cnt1 (- numlen 1)) (rtos num 2 1)) (setq sp 1))
  23.                 ((= (substr txt cnt1 (- numlen 3)) (rtos num 2 0)) (setq sp 3))
  24.             );cond      
  25.             (setq rtxt (substr txt (- (+ cnt1 numlen) sp) len)
  26.                   num (+ add num)
  27.                   numt (rtos num 2 5)
  28.                   ntx  (strcat (substr txt 1 (-  cnt1 1)) numt rtxt)
  29.                   old (assoc 1 dent)
  30.                   new (cons 1 ntx)
  31.                   dent (subst new old dent)   
  32.                   cnt1 (+ 1 len)
  33.                );setq
  34.                 (entmod dent)
  35.                );progn
  36.              )));if,progn,if
  37.         (setq cnt1 (1+ cnt1))      
  38.       );end while
  39.   (setq cnt (1+ cnt))   
  40. );while
  41. );defun
  42. [/font]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2003-4-10 11:47:48 | 显示全部楼层
哈。。哈。。
我正需要这个,以前我编的不太好用,呵。。
不劳而获了
谢谢!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-10 12:13:59 | 显示全部楼层
是否太繁琐了? 用mapcar函数不是很简单吗?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-15 10:06:22 | 显示全部楼层
不过,对不起,今天我没有带来
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-23 10:29:50 | 显示全部楼层
该程序在修改较大数时,就不灵通了。我是初学者,能不能再修改一下,重新定义一下数的精度
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-25 08:24:56 | 显示全部楼层
如果是a1~a8这样的系列就不能执行,能否改进一下?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-5-2 00:33:16 | 显示全部楼层
贴一个以前的程序,后来没再处理:

  1. (defun c:sxys(/ A B1 D72 D73 DW E EN H IN K-SXYS
  2.               K-YS LAY N P0 P1 S TXT TXT1 TXT2 WS)
  3.   (diag-sxys)
  4.   (prompt "\n选择要统一修改的文字:")
  5.   (setq s(ssget '((0 . "TEXT")) ) n(sslength s) in 0)
  6.   (repeat n
  7.     (setq e(ssname s in) in (1+ in)
  8.           en(entget e) txt (atof (dxf 1 en))
  9.           p0(dxf 10 en)h(dxf 40 en)lay(dxf 8 en)
  10.           a(dxf 50 en)p1(polar p0 (- a a:pi2) (* 1.5 h))
  11.           d72 (dxf 72 en)d73(dxf 73 en))
  12.     (if (and k-sxys k-ys ws (if (member k-ys '("1" "2" "3")) b1 T))(progn
  13.       (cond
  14.         ((= k-ys "1")(setq txt1(rtos (+ txt b1) 2 ws)
  15.                            txt2(strcat (rtos txt 2 ws) (if (> b1 0)"+" "-") (rtos (abs b1) 2 ws)"=")))
  16.         ((= k-ys "2")(setq txt1(rtos (* txt b1) 2 ws)
  17.                            txt2(strcat (rtos txt 2 ws) "x" (rtos b1 2 ws)"=")))
  18.         ((= k-ys "3")(setq txt1(rtos (/ txt b1) 2 ws)
  19.                            txt2(strcat (rtos txt 2 ws) "/" (rtos b1 2 ws)"=")))
  20.         ((= k-ys "4")(setq txt1(rtos (* txt txt) 2 ws)
  21.                            txt2(strcat (rtos txt 2 ws) "平方=")))
  22.         ((= k-ys "5")(setq txt1(rtos (* (rtos txt 2 ws) (rtos txt 2 ws) (rtos txt 2 ws)) 2 ws)
  23.                            txt2(strcat (rtos txt 2 ws) "三次方=")))
  24.         ((= k-ys "6")(setq txt1(rtos (SQRT txt) 2 ws)
  25.                            txt2(strcat (rtos txt 2 ws) "开平方=")))
  26.       )
  27.       (if (and dw (= (type dw) 'str))(setq txt1(strcat txt1 dw)))
  28.       (if (= k-sxls "1")(progn
  29.         (#m_txt p1 txt2  "DXFS" h 0.7 a d72 d73 lay -1)
  30.         (setq p1(polar p1 (- a a:pi2) (* 1.5 h)))
  31.         (#m_txt p1 txt1 "DXFS" h 0.7 a d72 d73 lay -1)
  32.         )
  33.         (#m_txt p1 txt1 "DXFS" h 0.7 a d72 d73 lay -1)
  34.       )
  35.     ) )
  36.   )
  37. )
  38. (DEFUN diag-sxys (/ dcl_id dcl_id i )
  39.   (setq k-sxys T ws 2)
  40.   (IF (> (SETQ dcl_id (LOAD_DIALOG "jz8")) 0)(PROGN
  41.     (IF (NEW_DIALOG "sxys" dcl_id)(PROGN
  42.       (setq k-ys "1")
  43.       (set_tile "b2" (itoa ws))
  44.       (set_tile (strcat "a" k-ys) "1")
  45.       (set_tile "b5" (if k-sxls k-sxls "0"))
  46.       (ACTION_TILE "a1" "(setq k-ys "1")(mode_tile "b1" 0)")
  47.       (ACTION_TILE "a2" "(setq k-ys "2")(mode_tile "b1" 0)")
  48.       (ACTION_TILE "a3" "(setq k-ys "3")(mode_tile "b1" 0)")
  49.       (ACTION_TILE "a4" "(setq k-ys "4")(mode_tile "b1" 1)")
  50.       (ACTION_TILE "a5" "(setq k-ys "5")(mode_tile "b1" 1)")
  51.       (ACTION_TILE "a6" "(setq k-ys "6")(mode_tile "b1" 1)")
  52.       ;==
  53.       (ACTION_TILE "b1" "(setq b1(distof $value))")
  54.       (ACTION_TILE "b2" "(setq ws(atoi $value))")
  55.       (ACTION_TILE "b3" "(setq dw $value)")
  56.       (ACTION_TILE "b4" "(dw-sxys)")
  57.       (ACTION_TILE "b5" "(setq k-sxls $value)")
  58.       (ACTION_TILE"accept" "(ok-sxys)(done_dialog 1)")
  59. ;;;      (ACTION_TILE"help""(info_box_cyck-st)")
  60.       (ACTION_TILE "cancel" "(setq k-sxys nil)")
  61.       (START_DIALOG))
  62.       (PROMPT "\n无法显示对话框,请检查!")
  63.     )
  64.     (UNLOAD_DIALOG dcl_id))
  65.     (PRINC (STRCAT "\n无法加载对话框文件" tdcl ".DCL,请检查!"))
  66.   )
  67. )
  68. (defun dw-sxys()
  69.   (setq xyz '("m%%1412%%142" "千米%%1412%%142" "米""户")
  70.         dw(dos_combolist "--by陈勇--" "选择一个单位" xyz "m%%1412%%142"))
  71.   (set_tile "b3" dw)
  72. )


  73. (defun ok-sxys()
  74.   (setq        b1(atof(get_tile "b1"))
  75.         ws(atoi(get_tile "b2"))
  76.         dw(get_tile "b3")
  77.         k-sxls(get_tile "b5"))
  78. )

  79. ;;;内部函数
  80. (defun #m_txt (pt txt sty th wid tan d72 d73 lay color /)
  81. (if (and (= d72 0)(= d73 0))
  82.   (setq en000 (list
  83.       (cons 0 "TEXT")
  84.       (cons 1 txt)
  85.       (cons 7 sty)
  86.       (cons 8 lay)
  87.       (cons 10 pt)
  88.       (cons 40 th)
  89.       (cons 41 wid)
  90.       (cons 50 tan)
  91.       (cons 72 d72)
  92.       (cons 73 d73)   ) )
  93.   (setq en000 (list
  94.       (cons 0 "TEXT")
  95.       (cons 1 txt)
  96.       (cons 7 sty)
  97.       (cons 8 lay)
  98.       (cons 10 pt)
  99.       (cons 11 pt)
  100.       (cons 40 th)
  101.       (cons 41 wid)
  102.       (cons 50 tan)
  103.       (cons 72 d72)
  104.       (cons 73 d73)   ) )
  105.   )
  106.   (IF (= STY "STANDARD")(setq en000 (append en000 (list (cons 51 0.261799)))))
  107.   (if (/= -1 color) (setq en000 (append en000 (list (cons 62 color)))))
  108.   (if (= nil (entmake en000)) (princ "\n制造 TEXT 实体失败.")  )
  109. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-5-2 00:37:31 | 显示全部楼层
下面是dcl
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-5-2 02:16:08 | 显示全部楼层

  1. (princ "\ntadd=====txt数字加减值,改精度----------- lxx.2001.6")
  2. (defun c:tadd ( / ss i nall ent entl i nmb nall nalls k dec)
  3.   (princ "\ntcal=====txt数字加减值,改精度----------- lxx.2001.6")
  4.   (setq ss (ssget '((0 . "TEXT")))
  5.         i 0
  6.         nadd (getdist "\n加值(可为负值;直接回车改精度):")
  7.         dec (getint "\n精度<0>:")
  8.   )
  9.   (if (not nadd)(setq nadd 0))
  10.   (if (not dec)(setq dec 0))
  11.   (repeat (sslength ss)
  12.     (setq ent (ssname ss i)
  13.           entl (entget ent)
  14.           i (1+ i)
  15.           nmb (cdr(assoc 1 entl))
  16.     )
  17.     (if (or (= 'REAL (type (read nmb)))(= 'INT (type (read nmb))))
  18.         (progn
  19.           (setq  nmb (atof nmb)
  20.                endn (+ nmb nadd)
  21.                  nmb (rtos endn 2 dec)
  22.                entl (subst (cons 1 nmb)(assoc 1 entl) entl)
  23.           )
  24.         (entmod entl)
  25.         )
  26.     );;end if
  27.   )  ;;end repeat
  28.   (princ)
  29. )
  30. ;;;;
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-7-29 15:06:44 | 显示全部楼层
不知怎么使用?给个演示就好了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2009-11-5 09:51:53 | 显示全部楼层
想下载但是积分不够!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2009-11-5 12:36:28 | 显示全部楼层
defun c:   后面是命令  自己可以看看   
下了  谢啦
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2009-11-28 11:23:15 | 显示全部楼层
9楼的很好用, 哈哈 谢谢了,
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 691个

财富等级: 财运亨通

发表于 2009-11-29 02:21:50 | 显示全部楼层
(defun test (x)
  (setq sgt (ssget '((0 . "text"))))
  (setq ii 0)
  (repeat (sslength sgt)
    (setq ent (ssname sgt ii))
    (setq entlst (entget ent))
    (setq str (cdr (assoc 1 entlst)))
    (setq num (atof str))
    (setq num (+ num x))
    (setq str2 (rtos num))
    (setq namelst (subst (cons 1 str2) (assoc '1 entlst) entlst))
    (entmod namelst)
    (setq ii (1+ ii))
  ) ;_ &frac12;á&Ecirc;&oslash;repeat
) ;_ &frac12;á&Ecirc;&oslash;defun
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2009-12-1 14:43:14 | 显示全部楼层
9楼的黏贴下来直接放在text文本里用好像不行?



呵呵,好像是把\"替换为"就可以了,自己搞错了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-5-9 20:52 , Processed in 0.413980 second(s), 60 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表