| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3805 人关注过本帖, 1 人收藏
标题:按条件导入Excel 数据到 listbox ??
只看楼主 加入收藏
xiangyue0510
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:86
帖 子:941
专家分:5244
注 册:2015-8-10
收藏
得分:0 
以下是引用newsoftware在2017-7-26 23:54:02的发言:

感谢版主回复!版主讲得太对了,很多东西都还给老师了,知识真的是用时方恨少呀!

但还要以下的第2个条件:“编号列为升序排序”时再导入,现导入的顺序与我想要的不一样,还请版主再指教? 感谢了。

条件如下(VB操作):
1、GP9列筛选非空项
2、筛选后编号列为升序排序
3、提取Orders列的后3位数导入到VB的listbox


现导入的顺序与我想要的不一样,如下图:



PS:
 if Xlssheet.Cells(i, 7)<>"" then List1.AddItem right(Xlssheet.Cells(i, 2) ,3)

还的够干净的,感觉你是一点不留
需要排序的话先把这些编号放在一个动态数组中,然后排序,最后放进list中
动态数组这个给你一段代码,排序这个自己研究一下。
dim nums()
dim k as integer
for i = N1 to N2
    if Xlssheet.Cells(4, 7)<>"" then
     'List1.AddItem right(Xlssheet.Cells(4, 2) ,3)
     redim preserve nums(k)     'preserve 很重要,在改变数组上限的时候不清空原来的数据,要不就相当于重新定义一个数组,都是空的
     nums(k)=right(Xlssheet.Cells(4, 2) ,3)
     k=k+1
    end if
 next i

next
2017-07-27 08:58
newsoftware
Rank: 1
等 级:新手上路
帖 子:31
专家分:0
注 册:2017-7-21
收藏
得分:0 
以下是引用ZHRXJR在2017-7-27 07:12:32的发言:



添加这二个引用,就可以了。


已引用,出现以下错误提示,不知是否安装的问题 ?。。。。

图片附件: 游客没有浏览图片的权限,请 登录注册
图片附件: 游客没有浏览图片的权限,请 登录注册
2017-07-27 21:52
newsoftware
Rank: 1
等 级:新手上路
帖 子:31
专家分:0
注 册:2017-7-21
收藏
得分:0 
以下是引用xiangyue0510在2017-7-27 08:58:55的发言:


还的够干净的,感觉你是一点不留
需要排序的话先把这些编号放在一个动态数组中,然后排序,最后放进list中
动态数组这个给你一段代码,排序这个自己研究一下。
dim nums()
dim k as integer
for i = N1 to N2
    if Xlssheet.Cells(4, 7)<>"" then
     'List1.AddItem right(Xlssheet.Cells(4, 2) ,3)
     redim preserve nums(k)     'preserve 很重要,在改变数组上限的时候不清空原来的数据,要不就相当于重新定义一个数组,都是空的
     nums(k)=right(Xlssheet.Cells(4, 2) ,3)
     k=k+1
    end if
 next i

next


我是菜鸟,这代码看不懂

我是说要按“编号”列升序的顺序来导入数据,就是如下图所示的顺序,但不是在excel 操作,而是要在VB操作。这代码感觉是用导入的数据来排序。。。

图片附件: 游客没有浏览图片的权限,请 登录注册
2017-07-27 22:07
ZHRXJR
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:125
帖 子:1034
专家分:5519
注 册:2016-5-10
收藏
得分:0 
回复 12楼 newsoftware
cnn.Open "Provider=Microsoft.Ace.OLEDB.12.0;Extended Properties=Excel 12.0;Data Source=" & App.Path & "\Excel表.xlsx"
这个是Excel 2007 以上版本的驱动程序,你系统中安装的是那个版本的Office,有可能是没有 ACE.OLEDB.12.0 的驱动引起的。
要不然换成2003的Excel:
cnn.Open  "Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=false;Data Source=" & App.Path & "\Excel表.xls;Extended Properties='Excel 8.0;HDR=Yes'"
注意,扩展名必须是 *.xls,不是 *.xlsx 。

[此贴子已经被作者于2017-7-27 22:58编辑过]


请不要选我!!!
2017-07-27 22:55
快速回复:按条件导入Excel 数据到 listbox ??
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.018868 second(s), 11 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved