【问题标题】:dart - select group of string use RegExpdart - 使用 RegExp 选择字符串组
【发布时间】:2021-01-07 09:17:11
【问题描述】:

从我的字符串中搜索并提取字符串组:
我的字符串
hello, my name is dev and ..., OK :#E8J+Yng==#::#E8J+Yng==#:, and i just:#E8J+YjQ==#:,:#E8J+YsA==#:

原来的字符串是 hello, my name is dev and ..., OK ????????, and i just????,???? 我通过下面的类得到这个字符串

import 'dart:convert' as converter;

class EmojiMessages{
  static String regStr=r"(?:[\u2700-\u27bf]|(?:\ud83c[\udde6-\uddff]){2}|[\ud800-\udbff][\udc00-\udfff]|[\u0023-\u0039]\ufe0f?\u20e3|\u3299|\u3297|\u303d|\u3030|\u24c2|\ud83c[\udd70-\udd71]|\ud83c[\udd7e-\udd7f]|\ud83c\udd8e|\ud83c[\udd91-\udd9a]|\ud83c[\udde6-\uddff]|\ud83c[\ude01-\ude02]|\ud83c\ude1a|\ud83c\ude2f|\ud83c[\ude32-\ude3a]|\ud83c[\ude50-\ude51]|\u203c|\u2049|[\u25aa-\u25ab]|\u25b6|\u25c0|[\u25fb-\u25fe]|\u00a9|\u00ae|\u2122|\u2139|\ud83c\udc04|[\u2600-\u26FF]|\u2b05|\u2b06|\u2b07|\u2b1b|\u2b1c|\u2b50|\u2b55|\u231a|\u231b|\u2328|\u23cf|[\u23e9-\u23f3]|[\u23f8-\u23fa]|\ud83c\udccf|\u2934|\u2935|[\u2190-\u21ff])";
  static RegExp regExp=RegExp(regStr);
  static String startEmoji=":#E";
  static String endEmoji="#:";

  static String encodeEmojiText(String msg){
    List<String> emojis=regExp.allMatches(msg).map((e)=>e.group(0)).toList();
    List<String> codedEmojis=emojis.map((e)=>startEmoji+converter.base64.encode(converter.utf8.encode(e))+endEmoji).toList();
    for(var i=0; i<emojis.length; i++){
      msg=msg.replaceAll(emojis[i], codedEmojis[i]);
    }
    return msg;
  }

  static String decodeEmojiText(String msg){
    //todo revers emoji base64
    return msg;
  }
}

var str="hello, my name is dev and ..., OK ????????, and i just????,????";
print(EmojiMessages.encodeEmojiText(str));//hello, my name is dev and ..., OK :#E8J+Yng==#::#E8J+Yng==#:, and i just:#E8J+YjQ==#:,:#E8J+YsA==#:

我需要什么,只需将顶部代码(如正则表达式)反转为选择 :#Ebase64#:
再次获取原始字符串。

我为什么要这样做?

存储不带空格的数据,在我的API中需要发送普通消息字符串

    • 如果编码 base64 方式为假,请告诉我。
    • 如果 base64 编码方式不可逆,请告诉我。
    • 请耐心等待,我在 RegExp 上很弱。

谢谢ThaiKV

【问题讨论】:

    标签: regex flutter dart base64 emoji


    【解决方案1】:

    您可以选择任何类型的纯文本表示来保证您的 Unicode 数据在转换为 ASCII 时的安全,Base64 是一种安全格式。

    您编写编码方法的方式不是最佳的,当您需要将子字符串与正则表达式匹配时,您应该使用.replaceAllMapped,对其进行操作然后粘贴回字符串中。首先提取匹配项,转换数据并在每次操作后运行替换是资源消耗。

    所以,我会把你的EmojiMessages 类写成如下:

    class EmojiMessages{
      static String regStr=r"(?:[\u2700-\u27bf]|(?:\ud83c[\udde6-\uddff]){2}|[\ud800-\udbff][\udc00-\udfff]|[\u0023-\u0039]\ufe0f?\u20e3|\u3299|\u3297|\u303d|\u3030|\u24c2|\ud83c[\udd70-\udd71]|\ud83c[\udd7e-\udd7f]|\ud83c\udd8e|\ud83c[\udd91-\udd9a]|\ud83c[\udde6-\uddff]|\ud83c[\ude01-\ude02]|\ud83c\ude1a|\ud83c\ude2f|\ud83c[\ude32-\ude3a]|\ud83c[\ude50-\ude51]|\u203c|\u2049|[\u25aa-\u25ab]|\u25b6|\u25c0|[\u25fb-\u25fe]|\u00a9|\u00ae|\u2122|\u2139|\ud83c\udc04|[\u2600-\u26FF]|\u2b05|\u2b06|\u2b07|\u2b1b|\u2b1c|\u2b50|\u2b55|\u231a|\u231b|\u2328|\u23cf|[\u23e9-\u23f3]|[\u23f8-\u23fa]|\ud83c\udccf|\u2934|\u2935|[\u2190-\u21ff])";
      static String startEmoji=":#E";
      static String endEmoji="#:";
      static RegExp regExp=RegExp(regStr);
      static RegExp regExp_dec_emoji = new RegExp("$startEmoji(.*?)$endEmoji");
    
      static String encodeEmojiText(String msg){
        return msg.replaceAllMapped(regExp, 
            (Match m) => "$startEmoji${converter.base64.encode(converter.utf8.encode(m[0]))}$endEmoji");
      }
      static String decodeEmojiText(String msg){
        return msg.replaceAllMapped(regExp_dec_emoji, 
            (Match m) => converter.utf8.decode(converter.base64.decode(m[1])));
      }
    }
    

    测试:

    var str="hello, my name is dev and ..., OK ??, and i just?,?";
    print(str);
    // => hello, my name is dev and ..., OK ??, and i just?,?
    String encstr = EmojiMessages.encodeEmojiText(str);
    print(encstr);
    // => hello, my name is dev and ..., OK :#E8J+Yng==#::#E8J+Yng==#:, and i just:#E8J+YjQ==#:,:#E8J+YsA==#:
    print(EmojiMessages.decodeEmojiText(encstr));
    // => hello, my name is dev and ..., OK ??, and i just?,?
    

    注意事项

    • regExp_dec_emoji 是一个简单的正则表达式,用于捕获两个字符串之间的任何类型的零个或多个字符(换行符除外),:#E(.*?)#:
    • converter.utf8.decode(converter.base64.decode(m[1])) 用于解码 Group 1 值,即:#E 和最左边的#: 之间的字符串。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-11-19
      • 1970-01-01
      相关资源
      最近更新 更多