AutoLisp 返回字符串中某一子串首次出現的位置的函數


 1 ;返回字符串中某一子串首次出現的位置
 2 (defun my_strstr(mstr zstr / retu)
 3     (setq mstr_l (strlen mstr) zstr_l (strlen zstr))
 4     (if (<= zstr_l mstr_l)
 5         ;主字符串長度大於或等於子字符長度
 6         (progn 
 7             (setq i 1)
 8             (setq tc_w1 T) ;退出循環時使用
 9             (setq ppqk nil) ;表示匹配情況
10             (while (and tc_w1 (<= i (+ 1 (- mstr_l zstr_l))))
11                 (setq j 1)
12                 (setq tc_w2 T)  ;退出循環時使用
13 
14                 ;對子串的每一個字符逐一比較
15                 (while (and tc_w2 (<= j zstr_l))
16                     (if (= (substr mstr (+ i (- j 1)) 1) (substr zstr j 1))
17                         (setq j (+ j 1))
18                         (setq tc_w2 nil)
19                     
20                     )
21                 )
22                 (if (= j (+ 1 zstr_l))
23                     (progn (setq tc_w1 nil ppqk i))
24                     (setq i (+ 1 i))
25                 )
26             
27             )
28             (setq retu ppqk)
29         
30         )
31         
32         ;否則
33         (setq retu nil)
34     
35     )
36     
37 )
38 
39 
40 (print (strstr "ABCDEFG" "EFG"))

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM