Загрузка данных


Sub ВставитьТекстСНумерацией()
    ' ==== Единая запись отмены ====
    Dim undoRec As Object
    On Error Resume Next
    Set undoRec = Application.UndoRecord
    On Error GoTo 0
    If Not undoRec Is Nothing Then
        undoRec.StartCustomRecord "Вставить текст с нумерацией"
    End If

    Dim dataObj As Object
    Dim clipText As String
    Dim lines() As String
    Dim n As Long
    Dim i As Long
    Dim ws As Worksheet
    Dim r0 As Long, c0 As Long
    Dim rngData As Range

    ' 1. Получить текст из буфера обмена
    On Error Resume Next
    Set dataObj = CreateObject("New:{1C3B4210-F441-11CE-B9EA-00AA006B1A69}")
    On Error GoTo 0
    If dataObj Is Nothing Then
        MsgBox "Не удалось получить доступ к буферу обмена."
        If Not undoRec Is Nothing Then undoRec.EndCustomRecord
        Exit Sub
    End If
    dataObj.GetFromClipboard
    clipText = dataObj.GetText
    If Len(Trim(clipText)) = 0 Then
        MsgBox "Буфер обмена пуст или содержит не текст."
        If Not undoRec Is Nothing Then undoRec.EndCustomRecord
        Exit Sub
    End If

    ' 2. Разбить на строки (поддерживает vbCrLf, vbLf, vbCr)
    clipText = Replace(clipText, vbCrLf, vbLf)
    clipText = Replace(clipText, vbCr, vbLf)
    lines = Split(clipText, vbLf)
    ' Удалить пустые строки в конце
    Do While UBound(lines) >= 0 And Trim(lines(UBound(lines))) = ""
        ReDim Preserve lines(UBound(lines) - 1)
    Loop
    n = UBound(lines) + 1
    If n = 0 Then
        MsgBox "Не найдено ни одной непустой строки."
        If Not undoRec Is Nothing Then undoRec.EndCustomRecord
        Exit Sub
    End If

    Set ws = ActiveSheet
    r0 = ActiveCell.Row
    c0 = ActiveCell.Column

    Application.ScreenUpdating = False

    ' 3. Вставить недостающие строки ПЕРЕД активной ячейкой,
    '    чтобы не перезаписать существующие данные
    If n > 1 Then
        ' Диапазон строк, которые нужно вставить: со следующей строки до n-1
        ws.Range(ws.Rows(r0 + 1), ws.Rows(r0 + n - 1)).EntireRow.Insert Shift:=xlDown
    End If

    ' 4. Записать данные с нумерацией прямо в ячейки
    For i = 0 To n - 1
        If Len(Trim(lines(i))) > 0 Then
            lines(i) = StrConv(Trim(lines(i)), vbProperCase)
        End If
        ws.Cells(r0 + i, c0).Value = (i + 1) & ". " & lines(i)
    Next i

    ' 5. Очистить формат и задать шрифт Times New Roman, 11
    Set rngData = ws.Range(ws.Cells(r0, c0), ws.Cells(r0 + n - 1, c0))
    rngData.ClearFormats
    With rngData.Font
        .Name = "Times New Roman"
        .Size = 11
    End With

    ' 6. Выделить первую ячейку с данными
    ws.Cells(r0, c0).Activate

    Application.ScreenUpdating = True

    If Not undoRec Is Nothing Then undoRec.EndCustomRecord
    MsgBox "Вставлено " & n & " строк(и) с нумерацией."
End Sub