开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 137|回复: 7
收起左侧

[精币悬赏] 优化速度号码归属地提取

[复制链接]
结帖率:96% (25/26)
发表于 2026-4-7 22:36:58 | 显示全部楼层 |阅读模式   四川省成都市
500精币
有没有大佬帮我优化一下
一次处理上千条数据太慢了
小白学艺不精,跪求大佬

蓝奏云链接
https://wwaxw.lanzouq.com/iW3W13mpgn0f

签到天数: 2 天

发表于 2026-4-8 11:08:41 | 显示全部楼层   广东省深圳市
感谢分享,很给力!~
回复

使用道具 举报

签到天数: 2 天

发表于 2026-4-8 11:08:59 | 显示全部楼层   广东省深圳市
感谢分享,很给力!~
回复

使用道具 举报

结帖率:40% (2/5)

签到天数: 9 天

发表于 2026-4-8 11:35:49 | 显示全部楼层   广西壮族自治区南宁市
你是想通过啥方式提取?访问后台中间件接口提取?还是直接读mysql提取?还是使用Access库提取?
回复

使用道具 举报

结帖率:40% (2/5)

签到天数: 9 天

发表于 2026-4-8 11:36:27 | 显示全部楼层   广西壮族自治区南宁市
你是想通过什么方式提取?通过后台中间件接口还是mysql数据库还是access库?
回复

使用道具 举报

结帖率:95% (164/173)

签到天数: 13 天

发表于 2026-4-8 13:00:01 | 显示全部楼层   山东省德州市
放MYSQL去提取不行么
回复

使用道具 举报

结帖率:96% (25/26)
 楼主| 发表于 2026-4-8 19:23:32 | 显示全部楼层   四川省成都市
ww850832845 发表于 2026-4-8 11:35
你是想通过啥方式提取?访问后台中间件接口提取?还是直接读mysql提取?还是使用Access库提取? ...

直接读取,已经写好了,只是运行速度慢
回复

使用道具 举报

结帖率:100% (1/1)
发表于 2026-4-10 22:40:30 | 显示全部楼层   浙江省温州市
这么多天过去了,相信楼主已经自行解决了。
这里再给一个简单的方案,直接读取 ym_core.sql ,把里面的内容放到数组里。
这样可以直接通过数组下标来访问,十万个号码,毫秒内完成处理:
  
窗口程序集名保 留  保 留备 注
窗口程序集_启动窗口   
变量名类 型数组备 注
表格文本型2000000需要设置为程序集或全局变量

子程序名返回值类型公开备 注
初始化  
变量名类 型静态数组备 注
文本文本型 
数组文本型0
正则正则表达式 
整数型 
搜索结果搜索结果 
编号整数型 
地址文本型 
成员文本型 
内存分配加速优化 ()
如果真 (文件是否存在 (“ym_core.sql”))
调试输出 (“当前目录下 ym_core.sql 不存在!”)
返回 ()
文本 = UTF8到文本 (读入文件 (“ym_core.sql”))
数组 = 分割文本 (文本, #换行符, )
' 调试输出 (取数组成员数 (数组))
正则.创建 (“VALUES \('.+?', '.+?', '(.+?)', '(.+?)', '(.+?)', '(.+?)'”, )
计次循环首 (取数组成员数 (数组), 数)
成员 = 数组 []
搜索结果 = 正则.搜索 (成员, 1, )
如果真 (搜索结果.是否为空 ())
编号 = 到整数 (搜索结果.取子匹配文本 (成员, 1, ))
地址 = 搜索结果.取子匹配文本 (成员, 2, )
地址 = 地址 + “ ” + 搜索结果.取子匹配文本 (成员, 3, )
地址 = 地址 + “ ” + 搜索结果.取子匹配文本 (成员, 4, )
表格 [编号] = 地址

计次循环尾 ()
子程序名返回值类型公开备 注
获取地址文本型 
参数名类 型参考可空数组备 注
号码文本型
变量名类 型静态数组备 注
长整数型 
数 = 到长整数 (号码)
如果真 (数 < 1 数 > 20000000000)
返回 (“”)
数 = 到整数 (取文本左边 (号码, 7))
返回 (表格 [])
子程序名返回值类型公开备 注
__启动窗口_创建完毕  
变量名类 型静态数组备 注
整数型 
号码文本型100000
文本文本型 
无效号码整数型 
时间整数型 
' 需要放在程序启动时运行一次
初始化 ()
' 生成十万个号码
计次循环首 (取数组成员数 (号码), 数)
文本 = “1”到文本 (取随机数 (3, 9))
计次循环首 (9, )
文本 = 文本 + 到文本 (取随机数 (0, 9))
计次循环尾 ()
号码 [] = 文本
计次循环尾 ()
' 模拟对十万个号码进行处理
时间 = 取启动时间 ()
计次循环首 (取数组成员数 (号码), 数)
如果真 (获取地址 (号码 [])“”)
无效号码 = 无效号码 + 1

计次循环尾 ()
调试输出 (无效号码)
调试输出 (格式化文本 (“耗时: %.lf毫秒”, 取启动时间 () - 时间))


i支持库列表   支持库注释   
RegEx正则表达式支持库
spec特殊功能支持库
eAPI应用接口支持库

开始运行被调试程序
* 30155
* “耗时: 47毫秒”
被调试易程序运行完毕


注意,在上面的代码中,内存分配加速优化 这个模块非常关键,如果不使用,初始化过程会非常缓慢。
完整例子.zip (4.14 MB, 下载次数: 2)
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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