明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1194|回复: 0

[基础] .net 定义lisp字符串函数

[复制链接]
发表于 2019-10-27 20:52:57 | 显示全部楼层 |阅读模式
初学.net,写了几个lisp字符串函数,解决lisp字符串处理功能较弱,请指点

using System;
using System.Text.RegularExpressions;
using Autodesk.AutoCAD.ApplicationServices;
using Autodesk.AutoCAD.DatabaseServices;
using Autodesk.AutoCAD.EditorInput;
using Autodesk.AutoCAD.Geometry;
using Autodesk.AutoCAD.Runtime;
namespace commom_lib
{
    /// <summary>
    /// 辅助操作类
    /// </summary>
    public static partial class Tools

    {
        private static object results;

        /// <summary>
        /// 字符串替换,参数:被替换字符 旧字符 新字符
        /// </summary>
        /// <param name="rb"></param>
        /// <returns></returns>
        [LispFunction("zgx:str:replace")]
        public static string Lsp_stringreplace(ResultBuffer rb)
        {
            string iRtn = null;
            if (rb != null)
            {
                TypedValue[] tb = rb.AsArray();
                if (tb.Length == 3 && tb[0].TypeCode == (int)LispDataType.Text && tb[1].TypeCode == (int)LispDataType.Text && tb[2].TypeCode == (int)LispDataType.Text)
                {
                    string toreplace = tb[0].Value as string;
                    string oldstr = tb[1].Value as string;
                    string newstr = tb[2].Value as string;
                    iRtn = toreplace.Replace(oldstr, newstr);
                }
            }
            return iRtn;
        }
        /// <summary>
        /// 字符分割,同split,参数string seperator;
        /// (zgx:str:Split input seperator)
        /// </summary>
        /// <param name="rb"></param>
        /// <returns></returns>
        [LispFunction("zgx:str:Split")]
        public static ResultBuffer Lsp_stringSplit(ResultBuffer rb)
        {
            ResultBuffer reb = new ResultBuffer();
            try
            {
                if (rb != null)
                {
                    TypedValue[] tb = rb.AsArray();
                    //ResultBuffer reb = new ResultBuffer();
                    if (tb.Length == 2 && tb[0].TypeCode == (int)LispDataType.Text && tb[1].TypeCode == (int)LispDataType.Text)
                    {
                        string toReplace = tb[0].Value as string;
                        string sep = tb[1].Value as string;
                        string[] strArr = Regex.Split(toReplace, sep);
                        for (int i = 0; i < strArr.Length; i++)
                        {
                            if (strArr[i] != "")
                                reb.Add(new TypedValue((int)LispDataType.Text, strArr[i]));
                        }
                    }
                    else
                        reb = null;
                }
                else
                    reb = null;

            }
            catch (Autodesk.AutoCAD.Runtime.Exception ex)
            {

            }
            //如何判断reb为空?
            return reb;
        }
        /// <summary>
        /// 正则表达式,与晓东函数顺序一致;
        /// (zgx:regExps patten input [regoptions默认 1+2])
        /// </summary>
        /// <param name="rb"></param>
        /// <returns></returns>
        [LispFunction("zgx:regExps")]
        public static ResultBuffer Lsp_regexps(ResultBuffer rb)
        {
            ResultBuffer Rsb = new ResultBuffer();
            int RegOpts = 3;
            try
            {
                if (rb != null)
                {
                    TypedValue[] tb = rb.AsArray();
                    //ResultBuffer reb = new ResultBuffer();
                    if (tb.Length >= 2 & tb.Length <= 3 && tb[0].TypeCode == (int)LispDataType.Text && tb[1].TypeCode == (int)LispDataType.Text)
                    {
                        string pattern = tb[0].Value as string;
                        string s = tb[1].Value as string;
                        if (tb.Length == 3
                            && tb[2].TypeCode == (int)LispDataType.Int32
                            | tb[2].TypeCode == (int)LispDataType.Int16
                            )
                            RegOpts = Convert.ToInt32(tb[2].Value);
                        MatchCollection results = Regex.Matches(s, pattern, (RegexOptions)RegOpts);
                        if (results.Count > 0)
                            for (int i = 0; i < results.Count; i++)
                            {
                                if (results[i].Value != "")
                                    Rsb.Add(new TypedValue((int)LispDataType.Text, results[i].Value));
                            }
                        else
                            Rsb = null;
                    }
                    else
                        Rsb = null;
                }
                else
                    Rsb = null;

            }
            catch (Autodesk.AutoCAD.Runtime.Exception ex)
            {

            }
            //如何判断reb为空?
            return Rsb;
        }
        /// <summary>
        /// (zgx:regExpr pat input new [替换选项 替换次数T,仅替换一次])
        /// 0       None
        ///1       IgnoreCase
        ///2       Multiline
        ///4       ExplicitCapture
        ///8       Compiled
        ///16      Singleline
        ///32      IgnorePatternWhitespace
        ///64      RightToLeft
        ///256     ECMAScript
        ///512     CultureInvariant
        /// </summary>
        /// <param name="rb"></param>
        /// <returns></returns>
        [LispFunction("zgx:regExpr")]
        public static string Lsp_regexpr(ResultBuffer rb)
        {
            string Rtnstr = null;
            int RegOpts = 3;
            try
            {
                if (rb != null)
                {
                    TypedValue[] tb = rb.AsArray();
                    if (tb.Length >= 3 & tb.Length <= 5
                        && tb[0].TypeCode == (int)LispDataType.Text
                        && tb[1].TypeCode == (int)LispDataType.Text
                        && tb[2].TypeCode == (int)LispDataType.Text
                        )
                    {
                        string pattern = tb[0].Value as string;
                        string sInput = tb[1].Value as string;
                        string sNew = tb[2].Value as string;
                        int iCount = sInput.Length;
                        if (tb.Length >= 4 & tb.Length <= 5
                            && tb[3].TypeCode == (int)LispDataType.Int32
                            | tb[3].TypeCode == (int)LispDataType.Int16
                            )
                            RegOpts = Convert.ToInt32(tb[3].Value);
                        if (tb.Length == 5
                            && tb[4].Value != null
                            )
                            iCount = 1;
                        Regex reg = new Regex(pattern, (RegexOptions)RegOpts);
                        Rtnstr = reg.Replace(sInput, sNew, iCount);
                    }
                }
            }
            catch (Autodesk.AutoCAD.Runtime.Exception ex)
            {

            }
            return Rtnstr;
        }
        //string input = "aaaaaaaaaaa";
        //string pat = "a";
        //string newstring = "v";
        //Regex re = new Regex(pat);
        //string rtn = re.Replace(input, newstring, input.Length, 1);

        /// <summary>
        /// substr同lispsubstr,参数:字符串 起始位置(从1开始) 截取长度
        /// </summary>
        /// <param name="rb"></param>
        /// <returns></returns>
        [LispFunction("zgx:str:Substring")]
        public static string Lsp_stringSubstring(ResultBuffer rb)
        {
            string iRtn = null;
            if (rb == null) return null;
            try
            {
                TypedValue[] tb = rb.AsArray();
                if (tb.Length == 3 &&
                    tb[0].TypeCode == (int)LispDataType.Text &&
                    tb[1].TypeCode == (int)LispDataType.Int32 |
                    tb[1].TypeCode == (int)LispDataType.Int16 |
                    tb[1].TypeCode == (int)LispDataType.Double &&
                    tb[2].TypeCode == (int)LispDataType.Double |
                    tb[2].TypeCode == (int)LispDataType.Int32 |
                    tb[2].TypeCode == (int)LispDataType.Int16)
                {
                    string toReplace = tb[0].Value as string;
                    int strLen = toReplace.Length;
                    int start = Convert.ToInt32(tb[1].Value) - 1;
                    int Length = Convert.ToInt32(tb[2].Value);
                    if (start < 1)
                        start = 1;
                    if (start + Length > strLen)
                        Length = strLen - start;
                    iRtn = toReplace.Substring(start, Length);
                }

            }
            catch (Autodesk.AutoCAD.Runtime.Exception ex)
            {

            }
            return iRtn;
        }
        /// <summary>
        /// 返回字符串长度,汉字按一个字符计算;
        /// 输入:字符串
        /// </summary>
        /// <param name="rb"></param>
        /// <returns></returns>
        [LispFunction("zgx:str:length")]
        public static object Lsp_strlength(ResultBuffer rb)
        {
            object iRtn = null;
            if (rb == null) return null;
            TypedValue[] tb = rb.AsArray();
            try
            {
                if (tb.Length == 1 && tb[0].TypeCode == (int)LispDataType.Text)
                {
                    string toreplace = tb[0].Value as string;
                    iRtn = toreplace.Length;
                }

            }
            catch (Autodesk.AutoCAD.Runtime.Exception ex)
            {

            }
            return iRtn;

        }
    }
}

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

本版积分规则

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

GMT+8, 2025-1-10 00:23 , Processed in 0.171065 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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