开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 86|回复: 6
收起左侧

[易语言] 如何快速获取每行最老日期

[复制链接]
结帖率:87% (45/52)
发表于 3 小时前 | 显示全部楼层 |阅读模式   江苏省淮安市
20精币
2027-08-25,2027-08-31,2027-08-31,2027-09-23
2028-09-05,2028-10-07,2028-09-11
2027-09-30,2027-06-30
2027-11-18,2027-11-19
2027-10-31,2028-10-31
2028-10-31,2028-10-31,2028-10-31,2028-10-31,2028-10-31
2028-08-31,2028-08-31,2028-08-31,2028-08-31,2026-10-31,2026-10-31
2028-09-17,2028-09-17,2028-09-19
2028-09-12,2028-09-12
2027-11-30,2028-07-31
································
大量一行时间  如何快速最旧日期,比如2027-11-30,2028-07-31  这一行最老日期是2027-11-30
2028-08-31,2028-08-31,2028-08-31,2028-08-31,2026-10-31,2026-10-31这一行最老日期是2026-10-31

如何快速获取每行最老日期?代码怎么写


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

签到天数: 15 天

发表于 3 小时前 | 显示全部楼层   广东省惠州市
.版本 2 .支持库 spec  .子程序 _按钮1_被单击   调试输出 (取一行最老日期 (“2028-09-05,2028-10-07,2028-09-11”))  .子程序 取一行最老日期, 文本型 .参数 日期文本行, 文本型 .局部变量 日期数组, 文本型, , "0" .局部变量 i, 整数型 .局部变量 当前日期, 日期时间型 .局部变量 最老日期, 日期时间型 .局部变量 找到有效日期, 逻辑型  找到有效日期 = 假 最老日期 = 到时间 (“2099-12-31”)  日期数组 = 分割文本 (日期文本行, “,”, )  .计次循环首 (取数组成员数 (日期数组), i)      日期数组 [i] = 删首尾空 (日期数组 [i])      .如果真 (日期数组 [i] ≠ “”)         当前日期 = 到时间 (日期数组 [i])         找到有效日期 = 真          .如果 (当前日期 < 最老日期)             最老日期 = 当前日期         .否则          .如果结束      .如果真结束  .计次循环尾 ()  .如果 (找到有效日期)     返回 (到文本 (最老日期)) .否则     返回 (“”) .如果结束
回复

使用道具 举报

结帖率:95% (20/21)

签到天数: 15 天

发表于 3 小时前 | 显示全部楼层   广东省惠州市
.版本 2
.支持库 spec

.程序集 窗口程序集_启动窗口

.子程序 __启动窗口_创建完毕



.子程序 _按钮1_被单击


调试输出 (取一行最老日期 (“2028-09-05,2028-10-07,2028-09-11”))

.子程序 取一行最老日期, 文本型
.参数 日期文本行, 文本型
.局部变量 日期数组, 文本型, , "0"
.局部变量 i, 整数型
.局部变量 当前日期, 日期时间型
.局部变量 最老日期, 日期时间型
.局部变量 找到有效日期, 逻辑型

找到有效日期 = 假
最老日期 = 到时间 (“2099-12-31”)

日期数组 = 分割文本 (日期文本行, “,”, )

.计次循环首 (取数组成员数 (日期数组), i)

    日期数组 [i] = 删首尾空 (日期数组 [i])

    .如果真 (日期数组 [i] ≠ “”)
        当前日期 = 到时间 (日期数组 [i])
        找到有效日期 = 真

        .如果 (当前日期 < 最老日期)
            最老日期 = 当前日期
        .否则

        .如果结束

    .如果真结束

.计次循环尾 ()

.如果 (找到有效日期)
    返回 (到文本 (最老日期))
.否则
    返回 (“”)
.如果结束

回复

使用道具 举报

结帖率:88% (117/133)

签到天数: 18 天

发表于 3 小时前 | 显示全部楼层   广东省广州市
  
子程序名返回值类型公开备 注
取每行最旧日期 返回每行最旧日期,用换行符分隔
参数名类 型参考可空数组备 注
全部文本文本型
变量名类 型静态数组备 注
正则正则表达式类 
行数组文本型0
i整数型 
j整数型 
最旧文本型 
当前文本型 
行数组 = 分割文本 (全部文本, #换行符, )
计次循环首 (取数组成员数 (行数组), i)
' 正则匹配当前行所有日期
如果真 (正则.创建 (“\d{4}-\d{2}-\d{2}”, 行数组 [i], , , , ))
最旧 = 正则.取匹配文本 (1, )  ' 取第一个日期作为初始值
计次循环首 (正则.取匹配数量 () - 1, j)  ' 从第二个开始比较
当前 = 正则.取匹配文本 (j + 1, )
如果真 (当前 < 最旧)  ' YYYY-MM-DD格式可直接文本比较
最旧 = 当前

计次循环尾 ()
如果真 (最旧 ≠ “”)  ' 防止无匹配结果
调试输出 (最旧)


计次循环尾 ()


i支持库列表   支持库注释   
spec特殊功能支持库

回复

使用道具 举报

结帖率:89% (16/18)

签到天数: 2 天

发表于 3 小时前 | 显示全部楼层   四川省成都市
可以先按换行分成数组,再把每一行按逗号分割,然后逐个比较,保留最小日期。

如果日期格式固定都是 yyyy-mm-dd,其实直接按文本比较大小就行,因为这个格式的文本顺序和日期顺序一致。

思路:
1、分割文本得到每一行
2、每行再按 “,” 分割成日期数组
3、先取第一个当最旧日期
4、循环比较,遇到更小的就替换
5、把每行结果拼接输出

如果你需要,我建议你直接用“分割文本 + 计次循环 + 判断(当前日期 < 最旧日期)”来写,不一定非得上正则。

要是你愿意,我下一条可以直接给你补一份易语言完整例子。
回复

使用道具 举报

结帖率:33% (1/3)

签到天数: 18 天

发表于 3 小时前 | 显示全部楼层   福建省厦门市
  
子程序名返回值类型公开备 注
_按钮1_被单击  
调试输出 (取最小年份 (7))
子程序名返回值类型公开备 注
取最小年份文本型 
参数名类 型参考可空数组备 注
第几行整数型
变量名类 型静态数组备 注
分割的文本文本型0
行文本文本型0
i整数型 
最小日期日期时间型 
结果文本文本型 
分割的文本 = 分割文本 ( #文本, #换行符, )
如果真 (取数组成员数 (分割的文本) < 第几行)
返回 (“”)
行文本 = 分割文本 (分割的文本 [第几行], “,”, )
' 调试输出 (分割的文本 [第几行])
如果真 (取数组成员数 (行文本) ≤ 0)
返回 (“”)
最小日期 = 到时间 (行文本 [1])
结果文本 = 行文本 [1]
如果真 (取数组成员数 (行文本) = 1)
返回 (结果文本)

计次循环首 (取数组成员数 (行文本), i)
如果真 (i ≥ 2)
如果真 (最小日期 > 到时间 (行文本 [i]))
最小日期 = 到时间 (行文本 [i])
结果文本 = 行文本 [i]


计次循环尾 ()
' 调试输出 (结果文本)
返回 (结果文本)


i支持库列表   支持库注释   
spec特殊功能支持库


拿去拿去

回复

使用道具 举报

结帖率:100% (3/3)

签到天数: 18 天

发表于 2 小时前 | 显示全部楼层   重庆市重庆市
开始运行被调试程序
* “2027-08-25”
* “2028-09-05”
* “2026-10-31”
被调试易程序运行完毕

  
子程序名返回值类型公开备 注
_按钮1_被单击  
变量名类 型静态数组备 注
源文本文本型 
局_行数组文本型0
局_日期数组文本型0
局_最老日期文本型 
i整数型 
j整数型 
源文本 = “2027-08-25,2027-08-31,2027-08-31,2027-09-23”#换行符“2028-09-05,2028-10-07,2028-09-11”#换行符“2028-08-31,2028-08-31,2028-08-31,2028-08-31,2026-10-31,2026-10-31”
局_行数组 = 分割文本 (源文本, #换行符, )
计次循环首 (取数组成员数 (局_行数组), i)
如果真 (删首尾空 (局_行数组 [i])“”)
到循环尾 ()

局_日期数组 = 分割文本 (局_行数组 [i], “,”, )
局_最老日期 = 局_日期数组 [1]
变量循环首 (2, 取数组成员数 (局_日期数组), 1, j)
如果真 (局_日期数组 [j] < 局_最老日期)
局_最老日期 = 局_日期数组 [j]

变量循环尾 ()
调试输出 (局_最老日期)
计次循环尾 ()


i支持库列表   支持库注释   
spec特殊功能支持库
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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