开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 292|回复: 5
收起左侧

[已解决] 分割文本比较复杂

 关闭 [复制链接]
结帖率:84% (61/73)
发表于 2025-9-5 20:04:29 | 显示全部楼层 |阅读模式   安徽省淮北市
20精币
我有一段数据 已经正则好了。源文本=“-我-不-大-额-不-看-汉-你-了-取-哦-的-是-啊-在- ”

局_正则.创建 (“-(.*?)-”, 源文本, 假, 假, 真,真)
计次循环首 (局_匹配数, 局_计次)
输出调试文本 (“匹配文本 ” + 到文本 (局_计次) + “ 中的子匹配文本 1:” + 局_正则.取子匹配文本 (局_计次, 1, ))

假如匹配到了 15个数据“    =  我不大额不看汉你了取哦的是啊在  

如何3个弄成一组 然后再加点符号 变成    *我不大*,*额不看*,*汉你了*  . . . . .. . . ..
如果匹配的 结果只有14个 3除不尽   那就 剩余的2个  为一组。

最后  把这一串 组合成一个文本。 最终结果   
文本=“*我不大**额不看**汉你了**取哦的*是啊在*”   这种格式。   严格按照这个格式来,不要加其他符号了


不要试图把原文本  替换或者更改。必须正则后的    然后组合成  一个文本 3个一串的

最佳答案

查看完整内容

[e=1].版本 2 .支持库 RegEx .支持库 spec .程序集 窗口程序集_启动窗口 .子程序 __启动窗口_创建完毕 .局部变量 文本, 文本型 .局部变量 结果, 文本型 .局部变量 正则, 正则表达式 文本 = “-我-不-大-额-不-看-汉-你-了-取-哦-的-是-啊-在- ” 结果 = 删全部空 (文本) 正则.创建 (“(-([^-]+))(-([^-]+))?(-([^-]+))?”, ) 结果 = 正则.替换 (结果, “\*$2$4$6\*”, 1, , 真, 真) 结果 = 取文本中间 (结果, 1, 取文本长度 ...

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值

结帖率:100% (1/1)
发表于 2025-9-5 20:04:30 | 显示全部楼层   浙江省温州市
  
窗口程序集名保 留  保 留备 注
窗口程序集_启动窗口   
子程序名返回值类型公开备 注
__启动窗口_创建完毕  
变量名类 型静态数组备 注
文本文本型 
结果文本型 
正则正则表达式 
文本 = “-我-不-大-额-不-看-汉-你-了-取-哦-的-是-啊-在- ”
结果 = 删全部空 (文本)
正则.创建 (“(-([^-]+))(-([^-]+))?(-([^-]+))?”, )
结果 = 正则.替换 (结果, “\*$2$4$6\*”, 1, , 真, )
结果 = 取文本中间 (结果, 1, 取文本长度 (结果) - 1)
调试输出 (文本)
调试输出 (结果)


i支持库列表   支持库注释   
RegEx正则表达式支持库
spec特殊功能支持库

开始运行被调试程序
* “-我-不-大-额-不-看-汉-你-了-取-哦-的-是-啊-在- ”
* “*我不大**额不看**汉你了**取哦的**是啊在*”
被调试易程序运行完毕

评分

参与人数 1荣誉 +1 收起 理由
笨潴 + 1 热心帮助他人,荣誉+1,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:100% (1/1)

签到天数: 27 天

发表于 2025-9-5 20:19:59 | 显示全部楼层   江西省南昌市
说话好硬气,佩服

点评

额....晕倒   安徽省淮北市  发表于 2025-9-5 20:39
回复

使用道具 举报

结帖率:100% (20/20)

签到天数: 28 天

发表于 2025-9-5 20:34:07 | 显示全部楼层   湖南省长沙市
import re

# 源文本
源文本 = "-我-不-大-额-不-看-汉-你-了-取-哦-的-是-啊-在-"

# 使用正则表达式匹配所有子字符串
pattern = "-(.*?)-"
matches = re.findall(pattern, 源文本)

# 将匹配结果每三个一组分组
groups = []
for i in range(0, len(matches), 3):
    group = matches[i:i+3]
    groups.append(''.join(group))

# 每组前后添加星号,并连接所有组
result = ''.join(['*' + group + '*' for group in groups])

print(result)

补充内容 (2025-9-5 20:34):
Python 代码

点评

大哥。python用AI就能写出来了 帮帮忙用易语言呗   安徽省淮北市  发表于 2025-9-5 20:40
回复

使用道具 举报

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

本版积分规则 致发广告者

关闭

精易论坛 - 有你更精彩上一条 /2 下一条

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备2025452707号) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

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