zoukankan      html  css  js  c++  java
  • 2018-5-20-C#-BBcode-转-Markdown

    title author date CreateTime categories
    C# BBcode 转 Markdown
    lindexi
    2018-05-20 14:58:57 +0800
    2018-2-13 17:23:3 +0800
    C#

    本文告诉大家一个简单的方法从 BBcode 转为 Markdown

    本文的方法都是使用正则转换,现在支持的代码只有很少的常用标签,如果大家发现有转换失败的,请帮我修改代码,估计代码我不会进行修改。

    最重要的就是转换 url 和 image,那么主要就告诉大家如何转换这两个

            private static string ConvertUrl(string str)
            {
                var regex = new Regex(@"[url=(.+?)]((?:.|
    )+?)[/url]");
                return regex.Replace(str, "[$2]($1)");
            }

    这就是转换 url 的代码,里面用了正则。一般使用正则拿到的数据就是(里的数据,如上面的代码,可能看起来有些复杂,那么用下面的代码告诉大家。

    例如 需要拿出 123lindexifoo中的 lindexi ,那么正则可以这样写

    123(lindexi)foo

    如果需要拿到 lindexi ,可以使用下面代码

               var regex = new Regex(@"123(lindexi)foo");
                if (regex.Match(str).Groups[1].Value == "lindexi")
                {
                    
                }

    实际使用会在 regex.Match 之后判断是否成功,而不是直接拿出来。从上面代码可以看到我使用了1而不是0,那么下面的代码拿到的字符串?

                var regex = new Regex(@"123(lindexi)foo");
                str = regex.Match(str).Groups[0].Value;

    这个 str 拿到是 123lindexifoo 就是原来匹配到的所有字符串。

    如果需要替换某个字符串,可以使用下面的代码

                str = "123lindexifoo";
                var regex = new Regex(@"123(lindexi)foo");
                str = regex.Replace(str, "csdn");
    
                str == "csdn"

    如果想把上面的字符串替换为 lindexi csdn ,那么可以使用下面代码

             str = "123lindexifoo";
                var regex = new Regex(@"123(lindexi)foo");
                str = regex.Replace(str, "$1csdn");

    可以看到上面的替换使用了 $1 ,这个就是第一个匹配拿到的字符串。如果需要拿第二个,就是使用$2,所以做这个很简单

    从上面的代码可以看到,转换 image 可以使用代码

                var regex = new Regex(@"[img]((?:.|
    )+?)[/img]");
                return regex.Replace(str, "![$1]($1)");

    转换其他的代码上传到 github ,如果是在我博客可以直接看到

    <script src="https://gist.github.com/lindexi/3ba74c909b23d6426c779d0a8eb435c3.js"></script>

  • 相关阅读:
    box-shadow做出一条线两种颜色
    调取手机摄像头拍照并获取拍得的照片
    PHP请求第三方接口的函数
    PHP mysqli类
    PHP CI框架最近学到的内容
    GE_OG_CALC_COLUMN_EMPTY
    Oracle分区知识
    创建理想的SEQUENCE和自增长的trigger
    Oracle的大数据类型,BIG DATA TYPE
    FOREIGN KEY相关
  • 原文地址:https://www.cnblogs.com/lindexi/p/12085578.html
Copyright © 2011-2022 走看看