明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
12
返回列表 发新帖
楼主: 77077

[源码] 选数求和,求积,求最大值,最小值...........欢迎大家一起来拓展,嘿嘿~~~

[复制链接]
发表于 2023-9-9 16:12:29 | 显示全部楼层
我已经帮你们实现了求和,  (setq K (getint "\n 最大值<1>,最小值<2>,求和<3>,求差<4>,求积<5>,求商<6>,求平均值<7>"))
并且输出字高为300,红色字体


  1. ;4-求最值QB
  2. (defun c:QB( /  sslst numlst num)
  3.    (defun ss->EnLst (ss / retu)
  4.        (setq retu (apply 'append (ssnamex ss)))
  5.        (setq retu (vl-remove-if-not '(lambda (x) (= (type x) 'ENAME)) retu))
  6.    )
  7.   (setq K (getint "\n 最大值<1>,最小值<2>,求和<3>,求差<4>,求积<5>,求商<6>,求平均值<7>"))
  8.   (setq sslst (ss->EnLst (ssget (list (cons 0 "TEXT") (cons 1 "~*[~`--9]*")))))
  9.   (setq numlst (mapcar '(lambda(x) (atof (cdr (assoc 1 (entget x))))) sslst))
  10.   (cond

  11.       ((= K 1)(setq num (apply 'max numlst)));;求最大值
  12.       ((= K 2)(setq num (apply 'min numlst)));;求最小值
  13.       ((= K 3)(setq num (apply '+ numlst)))
  14.       ((= K 4)(setq num (apply '- numlst)))
  15.       ((= K 5)(setq num (apply '* numlst)))
  16.       ((= K 6)(setq num (apply '/ numlst)))
  17.       ((= K 7)(setq num (/ (apply '+ numlst) (length numlst))));;平均数

  18.       (T (setq num (apply '+ numlst)))
  19.   )
  20.   (princ num)


  21. (setq insPt0 (getpoint "\n请输入计算结果插入点: "));;;计算结果显示在图中位置
  22. (setq bb (strcat "Z="(rtos num 2 3  )""));;;rtos num 2 2中 表示输出第一个2表示输出十进制,如果是1就是科学计数,第二个2表示输出2位小数
  23. (command "_text"  insPt0  300    "" bb 0 );;;300字高

  24.   (setq textEnt (entlast))
  25.   (entmod (append (entget textEnt) '((62 . 1))));;;设置文本颜色为红色


  26. (princ)
  27. )

本帖子中包含更多资源

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

x
发表于 2023-9-9 16:14:17 | 显示全部楼层

我已经帮你们实现了求和,  (setq K (getint "\n 最大值<1>,最小值<2>,求和<3>,求差<4>,求积<5>,求商<6>,求平均值<7>"))
并且输出字高为300,红色字体

  1. ;4-求最值QB
  2. (defun c:QB( /  sslst numlst num)
  3.    (defun ss->EnLst (ss / retu)
  4.        (setq retu (apply 'append (ssnamex ss)))
  5.        (setq retu (vl-remove-if-not '(lambda (x) (= (type x) 'ENAME)) retu))
  6.    )
  7.   (setq K (getint "\n 最大值<1>,最小值<2>,求和<3>,求差<4>,求积<5>,求商<6>,求平均值<7>"))
  8.   (setq sslst (ss->EnLst (ssget (list (cons 0 "TEXT") (cons 1 "~*[~`--9]*")))))
  9.   (setq numlst (mapcar '(lambda(x) (atof (cdr (assoc 1 (entget x))))) sslst))
  10.   (cond

  11.       ((= K 1)(setq num (apply 'max numlst)));;求最大值
  12.       ((= K 2)(setq num (apply 'min numlst)));;求最小值
  13.       ((= K 3)(setq num (apply '+ numlst)))
  14.       ((= K 4)(setq num (apply '- numlst)))
  15.       ((= K 5)(setq num (apply '* numlst)))
  16.       ((= K 6)(setq num (apply '/ numlst)))
  17.       ((= K 7)(setq num (/ (apply '+ numlst) (length numlst))));;平均数

  18.       (T (setq num (apply '+ numlst)))
  19.   )
  20.   (princ num)


  21. (setq insPt0 (getpoint "\n请输入计算结果插入点: "));;;计算结果显示在图中位置
  22. (setq bb (strcat "Z="(rtos num 2 3  )""));;;rtos num 2 2中 表示输出第一个2表示输出十进制,如果是1就是科学计数,第二个2表示输出2位小数
  23. (command "_text"  insPt0  300    "" bb 0 );;;300字高

  24.   (setq textEnt (entlast))
  25.   (entmod (append (entget textEnt) '((62 . 1))));;;设置文本颜色为红色


  26. (princ)
  27. )




  28. (princ)
  29. (defun prin()
  30. (princ "\n*************心雨编写2023-9,QQ12369867*************** ")
  31. (princ)
  32. )

本帖子中包含更多资源

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

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

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-6 09:47 , Processed in 0.150803 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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