明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1819|回复: 4

将具有分隔符的字符串解析为列表 的问题

[复制链接]
发表于 2008-10-15 16:27 | 显示全部楼层 |阅读模式
(StrParse Str Delimiter)

  说明:

将具有分隔符的字符串解析为列表

  函数内容:

(defun strParse (Str Delimiter / SearchStr StringLen return n char)
 (setq SearchStr Str)
 (setq StringLen (strlen SearchStr))
 (setq return '())


 (while (> StringLen 0)
  (setq n 1)
  (setq char (substr SearchStr 1 1))
  (while (and (/= char Delimiter) (/= char ""))
   (setq n (1+ n))
   (setq char (substr SearchStr n 1))
  ) ;_ end of while
  (setq return (cons (substr SearchStr 1 (1- n)) return))
  (setq SearchStr (substr SearchStr (1+ n) StringLen))
  (setq StringLen (strlen SearchStr))
 ) ;_ end of while
 (reverse return)
) ;_ end of defun

  参数:

Str:要解析的字符串
Delimiter :要搜索的分隔符

  返回值:

一个字符串列表

  示例:


(setq a "Harp,Guiness,Black and Tan")
(StrParse a ",")
返回:
("Harp" "Guiness" "Black and Tan")

上面的函数是否对于顿号("、")不起作用的 谢谢

(setq a "Harp、Guiness、Black and Tan")

 (StrParse a "、")

返回还是

("Harp、Guiness、Black and Tan")

"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2008-10-15 16:40 | 显示全部楼层
因为"、"是全角字,而比较时是半角,所以不成功.
 楼主| 发表于 2008-10-15 16:42 | 显示全部楼层

、 这个占了两个字符 晕 怪不得,一下忘了

 楼主| 发表于 2008-10-15 16:59 | 显示全部楼层

改了一下好像可以了  没时间自己再想了 将就用着先  嘿嘿

(defun C:aab ( / SearchStr StringLen return n char)
  (setq Str "aaate、btae12、c45、d313")
  (setq Delimiter "、")
 (setq SearchStr Str)
 (setq StringLen (strlen SearchStr))
 (setq return '())
 (while (> StringLen 0)
  (setq n 1)
  (setq char (substr SearchStr 1 2))
  (while (and (/= char Delimiter) (/= char ""))
   (setq n (1+ n))
   (setq char (substr SearchStr n 2))
  ) ;_ end of while
  (setq return (cons (substr SearchStr 1 (1- n)) return))
  (setq SearchStr (substr SearchStr (+ n 2) StringLen))
  (setq StringLen (strlen SearchStr))
 ) ;_ end of while
 (reverse return)
) ;_ end of defun

发表于 2008-10-20 07:57 | 显示全部楼层
  1. (defun txt-str-split (str x / lst n str-n xlen)
  2.   (setq xlen (strlen x))
  3.   (while (setq n (vl-string-search x str))
  4.     (setq str-n (substr str 1 n))
  5.     (if (/= str-n "")
  6.       (setq lst (cons str-n lst))
  7.     )
  8.     (setq str (substr str (+ 1 xlen n)))
  9.   )
  10.   (if (/= str "")
  11.     (setq lst (cons str lst))
  12.   )
  13.   (reverse lst)
  14. )
  15. ;;; 定界符分割文字成表,定界符去掉,定界符可以是多字符
  16. (defun t2-str-split (str x / lst n str-n xlen)
  17.   (setq xlen (strlen x))
  18.   (while (setq n (vl-string-search x str))
  19.     (setq str-n (substr str 1 (+ n xlen)))
  20.     (if (/= str-n "")
  21.       (setq lst (cons str-n lst))
  22.     )
  23.     (setq str (substr str (+ 1 xlen n)))
  24.   )
  25.   (if (/= str "")
  26.     (setq lst (cons str lst))
  27.   )
  28.   (reverse lst)
  29. )
  30. ;;; 定界符分割文字成表,定界符不去掉,定界符可以是多字符
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-4-26 18:17 , Processed in 0.372099 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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