包括打开提示,这就是我最终使用的。
将打开提示连接到一个按钮,以使非技术人员更容易使用:
Sub InsertRowAtChangeInValue()
Dim customerBook As Workbook
Dim filter As String
Dim caption As String
Dim customerFilename As String
Dim customerWorkbook As Workbook
Dim targetWorkbook As Workbook
Set targetWorkbook = Application.ActiveWorkbook
filter = "Excel 2007 files (*.xlsx),*.xlsx, Excel 97-03 files (*.xls),*xls, All files (*.*),*.*"
caption = "Please select an input file."
customerFilename = Application.GetOpenFilename(filter, , caption)
Set customerWorkbook = Application.Workbooks.Open(customerFilename)
Dim targetSheet As Worksheet
Set targetSheet = targetWorkbook.Worksheets(1)
Dim sourceSheet As Worksheet
Set sourceSheet = customerWorkbook.Worksheets(1)
targetSheet.Range("A1", "AR5000").Value = sourceSheet.Range("A1", "AR5000").Value
Dim lRow As Long
Dim sCol As String
Dim colNum As String
sCol = InputBox("Enter Column", sCol)
colNum = Columns(sCol).Column
For lRow = Cells(Cells.Rows.Count, sCol).End(xlUp).Row To 2 Step -1
If Cells(lRow, sCol) <> Cells(lRow - 1, sCol) Then
Rows(lRow).Insert
End If
Next lRow
End Sub
再次感谢您的帮助!