永发信息网

我有段vb程序是将excel的数据写入access的,请大家指教。

答案:2  悬赏:60  手机版
解决时间 2021-05-11 16:49

程序如下:

Private Sub Command1_Click()
Dim xlApp As New Excel.Application
Dim xlBook As New Excel.Workbook
Dim xlSheet As New Excel.Worksheet
Dim con As ADODB.Connection
Dim sql As String
Dim rs As New Recordset

'打开access表
Set con = New ADODB.Connection

con.Open "Provider=Microsoft.Jet.OLEDB.4.0;Persist Security Info=False;" & "Data Source=D:\Temp\tres.mdb"

rs.Open "select * from aa", con, adOpenKeyset, adLockOptimistic

'打开excel表
On Error Resume Next
   '后台进程运行excel程序,并得到该工作簿
   Set xlBook = xlApp.Workbooks.Open("D:\Temp\bb.xls")
  
   xlApp.Visible = False 'excel表不显示
  
   '获得该工作簿的“sheet1”表
   Set xlSheet = xlBook.Sheets("sheet1")
  
    xlSheet.Select
   
   '抽取b2格子的数据并赋值给text1.text
  
   For intcountrow = 2 To xlSheet.UsedRange.Rows.Count '行循环
  
       For intcountco = 1 To xlSheet.UsedRange.Rows.Count '列循环
      
          rs.Fields(intcountco - 1) = xlSheet.Cells(intcountrow, intcountco).Value '将excel的数据写入access中
         
       Next intcountco
      
       rs.MoveNext
      
   Next intcountrow
  
    Text1.Text = xlSheet.UsedRange.Columns.Count  'xlSheet.Range("b2")
   
    Text2.Text = rs.RecordCount       'xlSheet.Cells(3, 5).Value
   
   Set xlSheet = Nothing
   Set xlBook = Nothing
   xlApp.Quit
   Set xlApp = Nothing
   Set rs = Nothing
   Set con = Nothing
   rs.Close
   con.Close
  
End Sub
我excel表格中有5个字段,2行数据,但是写入access中却只有1行数据,并且只有3列字段,我看不出错在哪里?

最佳答案
只有3列字段,是因为:
For
intcountco = 1 To xlSheet.UsedRange.Rows.Count '列循环
改为
For
intcountco = 1 To xlSheet.UsedRange.columns.Count '列循环
就可以了。因为Rows正好是3行(连表头)。

只有一行数据,我看不出来,循环是对的,是否你rs.MoveNext用错了?
全部回答

For intcountrow = 2 To xlSheet.UsedRange.Rows.Count '行循环
  
    For intcountco = 1 To xlSheet.UsedRange.Rows.Count '列循环

问题应该在这里!

For intcountrow = 2 To xlSheet.UsedRange.Rows.Count '行循环
  
    For intcountco = 1 To xlSheet.UsedRange.Cols.Count '列循环

这个试下

我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
我的QQ农场偷东西老失败?
怎样才能得到碎矿石?各位知道答案的朋友帮帮
校运会开幕式的口号
梦幻西游里面怎么得到蓝色泡泡?
用小金铲挖小土堆最好在什么时候
我是1987年阴历6月16日早八点左右生女占卜婚
重庆到九寨沟开车多久,重庆到九寨沟多少公里
广西省的中国移动有没有“万花筒”业务?
步步高青花瓷i6能玩什么网游?
DNF天神1.56网路连接错误怎么办?
宽带连接为何接不上
龙之谷孤岛卡BOSS
心丢了要如何去找回
魔术快斗在线漫画
广东潮州的卡,现在还能开通流量多月租少的套
推荐资讯
奇葩说唐太宗的名言,中国历史比较出名的帝王
校园篮球风云
Sometimes silence is not only weak about
为什么有不少的年轻人爱看爱情片?
现在象40.50元开年钻的是真的假的?
完美国际72MG单刷12的最佳地方,冲级高手进,
上班的朋友进
《浮世绘》是周杰伦的新专辑吗?
福州的动车族
接到一个电话来电显示是17991,语音说是我家
带有语字的诗句急急急
998年12.12日射手座幸运颜色和数字以及吉祥物
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?