664571221 发表于 2020-8-11 14:45:03

求各位大神看下,吧这个求和的程序,改为求差

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;F13数字求和 SZQH
(defun c:SZQH ()
(setvar "cmdecho" 0)
   (setq jd 3)
      (setq s (ssget '((1 . "**")))) ;选择含数字文本
(setq k -1 mm 0.0 numdb '())
      (setq h2(cdr(assoc 40 (entget (ssname s 0)))))
(repeat (sslength s)
      (setq a (entget (ssname s (setq k(1+ k)))))
      (setq tx (cdr (assoc '1 a)))
                  (setq b (StrType tx)k2 -1)
                (repeat (length b)
                        (setq txt2(nth (setq k2(1+ k2))b))
                        (if (numberp (read txt2))
      (setq mm (+ (atof txt2) mm) numdb (cons txt2 numdb)))
                )
)
      (setq numdb(reverse numdb))
      (setq mm (strcat (strcat (car numdb) (apply 'strcat (mapcar '(lambda (x) (strcat "+" x)) (cdr numdb)))) "=" (rtos mm 2 jd)))


   (setq po (getpoint "\n指定计算结果的写入点:"))
               (entmake (list '(0 . "TEXT") (cons 1 mm)(cons 8 "0")(cons 10 po)(cons 40 h2)(cons 62 7)))

(setvar "cmdecho" 1)
      (princ)
)

(defun StrType(a / b c d e);;字符串分离全角、符号、字母、数字,存在问题:连续小数点与数字相连不能精确分离数字和小数点
(setq b(vl-string->list a))
(while b
    (setq a(car b)b(cdr b)c(last d))
    (if(or(not d)
               (and(< 0 a 32)(< 0 c 32));;非打印字符
               (or(= 46 a)(= 46 c)(and(< 47 a 58)(< 47 c 58)));数字和小数点
                           (vl-every'(lambda(x)(vl-some'(lambda(y)(<(car y)x(cadr y)))'((31 48)(57 65)(90 98)(122 129))))(list a c));其它字符包括小数点
               (vl-every'(lambda(x)(vl-some'(lambda(y)(<(car y)x(cadr y)))'((64 91)(96 123))))(list a c));;字母
             (and(> a 128)(> c 128)));;全角字符
       (if(> a 128)(setq d(vl-list*(car b)a d)b(cdr b))(setq d(cons a d)))
       (setq e(cons(reverse d)e)d(if(> a 128)(list(car b)a)(List a))b(if(> a 128)(cdr b)b))
                )
      )
(mapcar'vl-list->string(reverse(cons(reverse d)e)))
)

fan_zh 发表于 2020-8-11 14:56:51

求和,不分顺序,求差,是要有顺序的

664571221 发表于 2020-8-11 15:49:46

fan_zh 发表于 2020-8-11 14:56
求和,不分顺序,求差,是要有顺序的

你好大神顺序我用来点选,我第一个点的是被减数,后面的都是减数

bssurvey 发表于 2020-8-11 17:11:01

(setq mm (+ (atof txt2) mm) numdb (cons txt2 numdb)))
                )

(if (= mm 0.0)
        (setq mm (atof txt2) numdb (cons txt2 numdb))
        (setq mm (- mm (atof txt2)) numdb (cons txt2 numdb))
        ))
試試
前提是被減數要先選,一次框選會亂抓

664571221 发表于 2020-8-12 09:00:00

bssurvey 发表于 2020-8-11 17:11
(setq mm (+ (atof txt2) mm) numdb (cons txt2 numdb)))
                )



谢谢大神可以了呵呵呵
页: [1]
查看完整版本: 求各位大神看下,吧这个求和的程序,改为求差