gpt4 book ai didi

regex - dart - 使用 RegExp 选择字符串组

转载 作者:行者123 更新时间:2023-12-03 03:30:52 30 4
gpt4 key购买 nike

从我的字符串中搜索并提取字符串组:
我的字符串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😍,😰我通过以下类(class)得到这个字符串

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==#:
我需要什么 , 只需反转像正则表达式这样的顶级代码来选择 :#E base64 #:再次获取原始字符串。
我为什么要这样做?
存储没有空格字符的数据,在我的 API 中需要发送普通的消息字符串
  • 并请 :
  • 如果编码 base64 方式为假,请告诉我。
  • 如果编码 base64 方式不可逆,请告诉我。
  • 对我有耐心,我对 RegExp 很弱。


  • 谢谢 ThaiKV

    最佳答案

    您可以选择任何类型的纯文本表示,以在转换为 ASCII 时保证 Unicode 数据的安全,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]))用于解码第1组值,:#E之间的字符串和最左边的 #: .
  • 关于regex - dart - 使用 RegExp 选择字符串组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63989534/

    30 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com