开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 1771|回复: 12
收起左侧

[已解决] TXT文档导入高级表格

 关闭 [复制链接]
结帖率:100% (3/3)
发表于 2023-5-17 21:52:48 | 显示全部楼层 |阅读模式   湖北省咸宁市
15精币
就是把txt文档里面的导入到高级表格里面,
txt文档原件有制表符,有空值,平时编辑我都是直接复制到excel里面改的.现在想直接弄到高级表格里面操作,
实现能直接导入txt到高级表格里面,改其中的数据,然后保存,最好是能直接把txt拖到表格上直接加载

现在我遇到的问题是最后一列会跑到第一列里面去覆盖

就按附件里面的txt案例操作就行,

复制到excel里面是这个样子的,平时我就是复制在这里面编辑,高级表格里面我也希望实现这样的
Snipaste_2023-05-17_21-41-52.jpg

test.txt (211 Bytes, 下载次数: 9)

最佳答案

查看完整内容

[e=0].版本 2 .支持库 eGrid .子程序 导入Txt文档 .参数 Txt, 文本型 .局部变量 行数据, 文本型, , "0" .局部变量 列数据, 文本型, , "0" .局部变量 i, 整数型 .局部变量 k, 整数型 行数据 = 分割文本 (Txt, #换行符, ) 高级表格1.行数 = 取数组成员数 (行数据) ' 表头行数 = 0 .计次循环首 (取数组成员数 (行数据), i) 列数据 = 分割文本 (行数据 , 字符 (#Tab键), ) .如果真 (高级表格1.列数 < 取数组成员数 (列 ...

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

签到天数: 2 天

发表于 2023-5-17 21:52:49 | 显示全部楼层   广东省河源市
  
子程序名返回值类型公开备 注
导入Txt文档  
参数名类 型参考可空数组备 注
Txt文本型
变量名类 型静态数组备 注
行数据文本型0
列数据文本型0
i整数型 
k整数型 
行数据 = 分割文本 (Txt, #换行符, )
高级表格1.行数 = 取数组成员数 (行数据)  ' 表头行数 = 0
计次循环首 (取数组成员数 (行数据), i)
列数据 = 分割文本 (行数据 [i], 字符 ( #Tab键 ), )
如果真 (高级表格1.列数 < 取数组成员数 (列数据))
高级表格1.列数 = 取数组成员数 (列数据)  ' 表行列数 = 0

计次循环首 (取数组成员数 (列数据), k)
高级表格1.置数据 (i - 1, k - 1, 1, 列数据 [k])
计次循环尾 ()
计次循环尾 ()


i支持库列表   支持库注释   
eGrid高级表格支持库

回复

使用道具 举报

结帖率:100% (3/3)
 楼主| 发表于 2023-5-17 21:54:19 | 显示全部楼层   湖北省咸宁市
这个是我写的,还是有问题不行
  
子程序名返回值类型公开备 注
_按钮1_被单击  
变量名类 型静态数组备 注
数据文本型 
列数据文本型0
行数据文本型0
行数整数型 
列数整数型 
a1整数型 
a2整数型 
a3整数型 
数据 = 到文本 (读入文件 (取运行目录 ()“\test.txt”))
列数据 = 分割文本 (数据, 字符 (9) )
行数据 = 分割文本 (数据, #换行符, )
行数 = 取数组成员数 (行数据)
列数 = 取数组成员数 (列数据) ÷ 行数
调试输出 (“总数据:”到文本 (取数组成员数 (列数据)))
调试输出 (“列数:”到文本 (列数))
调试输出 (“行数:”到文本 (行数))
调试输出 (列数据)
调试输出 (行数据)
计次循环首 (行数, )
高级表格1.插入行 (, )
计次循环尾 ()
计次循环首 (列数 + 1, )
高级表格1.插入列 (, )
计次循环尾 ()
计次循环首 (行数, )
a3 = a3 + 1
计次循环首 (列数, )
a2 = a2 + 1
a1 = a1 + 1
高级表格1.置数据 (a3, a2, 1, 列数据 [a1])
高级表格1.置列宽 (a2, 60)
计次循环尾 ()
如果 (a2 ≥ 列数)
a2 = 0




计次循环尾 ()


i支持库列表   支持库注释   
spec特殊功能支持库
eGrid高级表格支持库

回复

使用道具 举报

结帖率:92% (49/53)
发表于 2023-5-17 22:13:52 | 显示全部楼层   吉林省长春市
计次循环首 (行数, )
高级表格1.插入行 (, )
计次循环尾 ()
计次循环首 (列数 + 1, )
高级表格1.插入列 (, )
计次循环尾 ()

这部分不需要如此麻烦 直接置2个属性即可
回复

使用道具 举报

结帖率:100% (3/3)
 楼主| 发表于 2023-5-17 22:17:29 | 显示全部楼层   湖北省咸宁市
空竹 发表于 2023-5-17 22:13
计次循环首 (行数, )
高级表格1.插入行 (, )
计次循环尾 ()

没有用,下标会提示错误,具体原因我发现使用制表符分割的时候每个空值数据会被忽略,比如总共有20条分割数据,有3个空值,但是取数组的时候只能算到17个
回复

使用道具 举报

结帖率:92% (49/53)
发表于 2023-5-17 22:18:51 | 显示全部楼层   吉林省长春市
小丸心° 发表于 2023-5-17 22:17
没有用,下标会提示错误,具体原因我发现使用制表符分割的时候每个空值数据会被忽略,比如总共有20条分割数 ...

你直接

高级表格1.行数=12
高级表格1.列数=13

我是这个意思,具体你代码,我没看
回复

使用道具 举报

结帖率:92% (49/53)
发表于 2023-5-17 22:19:32 | 显示全部楼层   吉林省长春市
你这代码写的比较混乱..

推荐思路:取得行数列数,然后2个变量循环完事
回复

使用道具 举报

结帖率:100% (3/3)
 楼主| 发表于 2023-5-17 22:19:49 | 显示全部楼层   湖北省咸宁市
空竹 发表于 2023-5-17 22:18
你直接

高级表格1.行数=12

建议看一下,因为这个txt文档不可能每一个都一样多的数据

点评

只是示意罢了!   吉林省长春市  发表于 2023-5-17 22:21
回复

使用道具 举报

结帖率:93% (14/15)

签到天数: 2 天

发表于 2023-5-17 22:21:56 | 显示全部楼层   广东省河源市
小丸心° 发表于 2023-5-17 22:19
建议看一下,因为这个txt文档不可能每一个都一样多的数据

因为每行数据数量不一样,所以要以每行数据数量为数组下标
回复

使用道具 举报

结帖率:92% (49/53)
发表于 2023-5-17 22:22:33 | 显示全部楼层   吉林省长春市
  
JSON.Parse (jsonStr)
row_count = JSON.get_int (“row_count”, )
col_count = JSON.get_int (“col_count”, )
调试输出 (row_count, col_count)
高级表格1.列数 = col_count
高级表格1.行数 = row_count
高级表格1.置自动换行 (0, 0, row_count - 1, col_count - 1, )
变量循环首 (0, row_count - 1, 1, row)
变量循环首 (0, col_count - 1, 1, col)
高级表格1.置行高 (row, 90)
高级表格1.置列宽 (col, 120)
高级表格1.置数据 (row, col, 1, JSON.get_string (“data.”到文本 (row)“.”到文本 (col), 真, , ))
' 调试输出 (JSON.get_string (“data.” + 到文本 (row) + “.” + 到文本 (col), 真, , ))
变量循环尾 ()
变量循环尾 ()
JSON.Clear ()


i支持库列表   支持库注释   
spec特殊功能支持库
eGrid高级表格支持库


上个代码你参考

补充内容 (2023-5-17 22:24):
个人觉得,简洁明了..

评分

参与人数 1精币 +1 收起 理由
小丸心° + 1 感谢分享,很给力!~

查看全部评分

回复

使用道具 举报

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

本版积分规则 致发广告者

关闭

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

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

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

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