Jump to content

Recommended Posts

Posted (edited)

Hi everybody.

I found this lisp on the forum 

This lisp is for Sum text, but this lisp only add interger part 

please review lisp and correct the decimal , example : 2000,35 + 1000,55 = 3000,90

thank you for your help

 

(defun C:STX (/ cpent elist en ip newtxt pt ss sum sumtxt txt)
(princ "\n\t\t>>>  Select text to get summ >>>")
(if
;;select texts/mtexts on screen :
(setq ss (ssget '((0 . "*TEXT"))))
;; if selected then :
(progn
 ;; store the first text entity for using 'em further :
(setq cpent (ssname ss 0))
 ;; set initial sum to zero :
 (setq sum 0.)
 ;; loop trough selected texts/mtexts :
 (while
   ;; get the first text in selection :
   (setq en (ssname ss 0))
   ;; get entity list of them :
   (setq elist (entget en))
   ;; get the textstring by key 1 from entity list :
   (setq txt (cdr (assoc 1 elist)))
   ;; create output string :
   (setq sumtxt
   ;; concatenate strings :
   (strcat
     ;; convert digits to string :
     (rtos
       ;; add to summ the digital value of text :
       (setq sum (+ (atof txt) sum))
       ;; 2 is for metric units (3 for engineering) :
       2
       ;; set precision by current :
       (getvar "dimdec")))
  )
   ;; delete entity from selection set :
   (ssdel en ss)
   )
 ;; display message in the command line:
 (princ (strcat "\nSumm=" sumtxt))
 (setq pt (getpoint "\nSpecify the new text location: "))
 ;; get the insertion point of stored entity :
 (setq ip (cdr (assoc 10 (entget cpent))))
 ;; copy text entity to the new destination point :
 (command "_copy" cpent "" ip pt)
 ;; get the last created entity :
 (setq newtxt (entlast))
 ;; get entity list of them :
 (setq elist (entget newtxt))
 ;; modify entity list with new text string :
 (entmod (subst (cons 1 sumtxt)(assoc 1 elist) elist))
 ;; update changes :
 (entupd newtxt)
 )
)
(princ)
 )
(princ "\nStart command with STX...")
(princ)

 

Edited by SLW210
Added Code Tags!!
Posted

These are not considered numbers:

2000,35 + 1000,55 = 3000,90

 

These are considered numbers:

2000.35 + 1000.55 = 3000.90

 

Anyway, A added 2 commands.

STXC if you use commas as the decimal point.

 

STXP if you use fullstop character ( "." ) as the decimal point.

 

(vl-load-com) 
  
(setq use_comma_as_decimal_point nil)
;;  With comma
(defun C:STXC ( / )
	(setq use_comma_as_decimal_point T)
	(C:STX)
)
;;  With fullstop character
(defun C:STXP ( / )
	(setq use_comma_as_decimal_point nil)
	(C:STX)
)

(defun C:STX (/ cpent elist en ip newtxt pt ss sum sumtxt txt)
	(princ "\n\t\t>>>  Select text to get summ >>>")
	(if
		;;select texts/mtexts on screen :
		(setq ss (ssget '((0 . "*TEXT"))))
		;; if selected then :
		(progn
			;; store the first text entity for using 'em further :
			(setq cpent (ssname ss 0))
			;; set initial sum to zero :
			(setq sum 0.)
			;; loop trough selected texts/mtexts :
			(while
				;; get the first text in selection :
				(setq en (ssname ss 0))
				;; get entity list of them :
				(setq elist (entget en))
				;; get the textstring by key 1 from entity list :
				(setq txt (cdr (assoc 1 elist)))
				
				(if use_comma_as_decimal_point
					;; replace comma by fullstop
					(setq txt (vl-string-subst "." "," txt))
				)
				
				;; create output string :
				(setq sumtxt
					;; concatenate strings :
					(strcat
						;; convert digits to string :
						(rtos
							;; add to summ the digital value of text :
							(setq sum (+ (atof txt) sum))
							;; 2 is for metric units (3 for engineering) :
							2
							;; set precision by current :
							(getvar "dimdec")
						)
					)
				)
				;; delete entity from selection set :
				(ssdel en ss)
			)
			;; display message in the command line:
			(princ (strcat "\nSumm=" sumtxt))
			(setq pt (getpoint "\nSpecify the new text location: "))
			;; get the insertion point of stored entity :
			(setq ip (cdr (assoc 10 (entget cpent))))
			;; copy text entity to the new destination point :
			(command "_copy" cpent "" ip pt)
			;; get the last created entity :
			(setq newtxt (entlast))
			;; get entity list of them :
			(setq elist (entget newtxt))
			
			(if use_comma_as_decimal_point
				;; replace fullstop by comma
				(setq sumtxt (vl-string-subst "," "." sumtxt))
			)
			
			;; modify entity list with new text string :
			(entmod (subst (cons 1 sumtxt)(assoc 1 elist) elist))
			;; update changes :
			(entupd newtxt)
		)
	)
	(princ)
	)
(princ "\nStart command with STX...")
(princ)

 

Posted (edited)

What this code does:

you select TEXT elements.  Each TEXT is supposed to only hold a numeric value.

Then a sum is made of each of the selected numbers.

Then you pick a point where the new TEXT comes, with the summed  value.

 

Here's an example

sum_texts.lsp.dwg

 

Edited by Emmanuel Delay
Posted

Please place code in code tags! (<> in the editor toolbar)

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...