Writing a string to a cell in excel

后端 未结 4 1837
花落未央
花落未央 2020-12-15 09:30

I am trying to write a value to the \"A1\" cell, but am getting the following error:

Application-defined or object-defined error \'1004\'

4条回答
  •  醉酒成梦
    2020-12-15 10:31

    I think you may be getting tripped up on the sheet protection. I streamlined your code a little and am explicitly setting references to the workbook and worksheet objects. In your example, you explicitly refer to the workbook and sheet when you're setting the TxtRng object, but not when you unprotect the sheet.

    Try this:

    Sub varchanger()
    
        Dim wb As Workbook
        Dim ws As Worksheet
        Dim TxtRng  As Range
    
        Set wb = ActiveWorkbook
        Set ws = wb.Sheets("Sheet1")
        'or ws.Unprotect Password:="yourpass"
        ws.Unprotect
    
        Set TxtRng = ws.Range("A1")
        TxtRng.Value = "SubTotal"
        'http://stackoverflow.com/questions/8253776/worksheet-protection-set-using-ws-protect-but-doesnt-unprotect-using-the-menu
        ' or ws.Protect Password:="yourpass"
        ws.Protect
    
    End Sub
    

    If I run the sub with ws.Unprotect commented out, I get a run-time error 1004. (Assuming I've protected the sheet and have the range locked.) Uncommenting the line allows the code to run fine.

    NOTES:

    1. I'm re-setting sheet protection after writing to the range. I'm assuming you want to do this if you had the sheet protected in the first place. If you are re-setting protection later after further processing, you'll need to remove that line.
    2. I removed the error handler. The Excel error message gives you a lot more detail than Err.number. You can put it back in once you get your code working and display whatever you want. Obviously you can use Err.Description as well.
    3. The Cells(1, 1) notation can cause a huge amount of grief. Be careful using it. Range("A1") is a lot easier for humans to parse and tends to prevent forehead-slapping mistakes.

提交回复
热议问题