如何将一个表按一定长度等分为N个表
程序中字符串太长,程序编译不了,如何将其按一定长度等分为N个表,然后将这N各表在串成一个表打包 上面说错了,不是等分,应该是比如表中有10500个元素,将其按2000长度分,最后剩余不足的为一个表 本帖最后由 cabinsummer 于 2011-10-12 18:16 编辑已存在的表为alist,flist为最终输出表,tlist为临时表
(defun devidelist(alist / flist tlist)
(setq tlist nil flist nil n 0)
(repeat (length alist)
(setq tlist (append tlist (list (nth n alist))))
(setq n (1+ n))
(if (= (rem n 2000) 0);余数为0,则将临时表追加到输出表后面,并将临时表重新置空
(progn
(setq flist (append flist (list tlist)))
(setq tlist nil)
)
)
)
(if tlist (setq flist (append flist (list tlist))));处理最后一组不够2000个的表
flist
)
感谢 cabinsummer 分享函数! cabinsummer 发表于 2011-10-12 07:18 static/image/common/back.gif
已存在的表为alist,flist为最终输出表,tlist为临时表
修改下,完美了,呵呵。
;;;alist 待分割表 ; m分格长度 ; flist 返回分完的表
;;;(devidelist '(1 2 3 4 5 6 7 8 9 10 11 12 13) 3)
;;;->((1 2 3) (4 5 6) (7 8 9) (10 11 12) (13))
(defun devidelist ( alist m / flist tlist n )
(setq tlist nil flist nil n 0)
(repeat (length alist)
(setq tlist (append tlist (list (nth n alist))))
(setq n (1+ n))
(if (= (rem n m) 0);余数为0,则将临时表追加到输出表后面,并将临时表重新置空
(progn
(setq flist (append flist (list tlist)))
(setq tlist nil)
)
)
)
(setq flist (append flist (list tlist)));处理最后一组不够2000个的表
flist
) duotu007 发表于 2011-10-12 08:50 static/image/common/back.gif
修改下,完美了,呵呵。
;;;alist 待分割表 ; m分格长度 ; flist 返回分完的表
;;;(devidelist '(1 2 3 ...
其实我写的那个根本就没有测试,感谢duotu007帮忙测试。看来效果还不错 本帖最后由 cabinsummer 于 2011-10-12 18:13 编辑
(defun devidelist ( alist m / flist tlist n )
(setq tlist nil flist nil n 0)
(repeat (length alist)
(setq tlist (append tlist (list (nth n alist))))
(setq n (1+ n))
(if (= (rem n m) 0)
(progn
(setq flist (append flist (list tlist)))
(setq tlist nil)
)
)
)
(if tlist (setq flist (append flist (list tlist))))
flist
) (defun devidelist (alist m / OUT OUT1)
(repeat (1+ (fix (/ (length alist) m)))
(setq out1 '())
(repeat (fix m)
(setq out1 (cons (car alist) out1)
alist (cdr alist)))
(setq out (cons (reverse (vl-remove nil out1)) out))
)
(reverse (vl-remove nil out))
)
页:
[1]