注册 登录
编程论坛 VB.NET论坛

VB写Excel的一个问题

marcodeba 发布于 2011-06-13 11:42, 879 次点击
毕业好多年了最近接手一个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仍然是可写的,不是只读的,网上搜了半天也找不到办法,不知道有没有高人指点下
5 回复
#2
haigecnpeng2011-06-18 21:30
xlBook.ChangeFileAccess Mode:=Excel.XlFileAccess.xlReadOnly
这句代码是将excel改为只读属性的,

只读属性的文件打开后是可以修改的,只是不能保存修改而已,可以另存的,

你希望的应该是表格保护之类的命令吧,不好意思我不会,不过可以试下用宏录制的代码改一下。
录制宏,保护工作表,得到以下代码,可以参考下
    Range("A1:J63").Select
    ActiveSheet.Protect DrawingObjects:=False, Contents:=True, Scenarios:= _
        False, AllowFormattingCells:=True, AllowFormattingColumns:=True, _
        AllowFormattingRows:=True, AllowInsertingColumns:=True, AllowInsertingRows _
        :=True, AllowInsertingHyperlinks:=True, AllowDeletingColumns:=True, _
        AllowDeletingRows:=True, AllowSorting:=True, AllowFiltering:=True, _
        AllowUsingPivotTables:=True
#3
不说也罢2011-06-21 11:40
楼主要弄清楚这是.net版块,而非VB6
#4
haigecnpeng2011-06-21 20:43
呵呵,都差不多的,我家里没.NET,没办法试,

我经常不知道office对象时,都用宏来参考的,宏用的是VBA,对于平台的话关系不大的。

我现在VB6跟VB。net都在用,容易混淆,不好意思啦。
#5
不说也罢2011-06-21 21:16
haigecnpeng ,你和楼主marcodeba是两个ID对应一个人?我说的是楼主啊。呵呵
#6
haigecnpeng2011-06-22 19:59
呵呵,不好意思,以为说楼上的啦,加上本来就心虚!
1