当前位置:编程学习 > VB >>

VB将Excel设置成只读问题

VB写Excel的一个问题


毕业好多年了最近接手一个VB的东西,功能是用VB把数据做成Excel报表,但是Excel要是只读的,我网上找了段测试代码如下
Private Sub Command1_Click()
On Error GoTo err_handle
  Dim xlApp As Excel.Application
  Dim xlBook As Excel.Workbook
  Dim xlsheet As Excel.Worksheet
  Set xlApp = CreateObject("Excel.Application")
  Set xlBook = xlApp.Workbooks.Add
  xlApp.Visible = False
  Set xlsheet = xlBook.Worksheets("Sheet1")
  xlApp.ScreenUpdating = False
  With xlsheet
  .Range("A1").Value = "A"
  .Range("B1").Value = "B"
  .Range("C1").Value = "C"
  .Range("D1").Value = "D"
  .Range("E1").Value = "E"
  .Range("F1").Value = "F"
  .Range("G1").Value = "G"
  .Range("H1").Value = "H"
  .Range("I1").Value = "I"
  End With
  'xlsheet.Range("A2").CopyFromRecordset Adodc2.Recordset
  xlsheet.Cells.HorizontalAlignment = xlCenter
  xlsheet.Cells.Font.Size = 12

xlsheet.Columns(1).ColumnWidth = 10
xlsheet.Columns(2).ColumnWidth = 10
xlsheet.Columns(3).ColumnWidth = 10
xlsheet.Columns(4).ColumnWidth = 16
xlsheet.Columns(5).ColumnWidth = 10
xlsheet.Columns(6).ColumnWidth = 16
xlsheet.Columns(7).ColumnWidth = 16
xlsheet.Columns(8).ColumnWidth = 10
xlsheet.Columns(9).ColumnWidth = 10

If Dir(App.Path & "\Excel", vbDirectory) = "" Then MkDir App.Path & "\Excel"
xlBook.SaveAs App.Path & "\Excel\Excel.xls"

xlBook.ChangeFileAccess Mode:=Excel.XlFileAccess.xlReadOnly

xlBook.Close
Set xlsheet = Nothing
Set xlBook = Nothing
xlApp.Quit
Set xlApp = Nothing
MsgBox "SUCCESS", , MsgTitle
err_handle:
End Sub
但是excel仍然是可写的,不是只读的,网上搜了半天也找不到办法,不知道有没有高人指点下


--------------------编程问答-------------------- 帮助文件中对于ChangeFileAccess方法有这样一句说明,不知道看了没有。

如果以只读模式打开文件,则不可独占访问此文件。如果将此文件从只读更改为可读写,Microsoft Excel 必须载入该文件的新副本以确认在以只读模式打开该文件后没有进行过更改。

--------------------编程问答-------------------- 用保护工作表的方法吧~~~
xBook.ActiveSheet.Protect Password:="123456", DrawingObjects:=True, Contents:=True, Scenarios:=True
补充:VB ,  VBA
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,