Làm cách nào để lưu trang tính dưới dạng tệp PDF và gửi qua email dưới dạng tệp đính kèm thông qua Outlook?
Trong một số trường hợp, bạn có thể cần gửi trang tính dưới dạng tệp PDF thông qua Outlook. Thông thường, bạn phải lưu trang tính theo cách thủ công dưới dạng tệp PDF, sau đó tạo một email mới với tệp PDF này dưới dạng tệp đính kèm trong Outlook của bạn và cuối cùng là gửi nó. Để đạt được nó theo cách thủ công từng bước rất tốn thời gian. Trong bài viết này, chúng tôi sẽ hướng dẫn bạn cách nhanh chóng lưu trang tính dưới dạng tệp PDF và gửi tự động dưới dạng tệp đính kèm thông qua Outlook trong Excel.
Lưu trang tính dưới dạng tệp PDF và gửi qua email dưới dạng tệp đính kèm với mã VBA
Lưu trang tính dưới dạng tệp PDF và gửi qua email dưới dạng tệp đính kèm với mã VBA
Bạn có thể chạy mã VBA dưới đây để tự động lưu trang tính đang hoạt động dưới dạng tệp PDF, sau đó gửi qua email dưới dạng tệp đính kèm thông qua Outlook. Hãy làm như sau.
1. Mở trang tính bạn sẽ lưu dưới dạng PDF và gửi, sau đó nhấn Khác + F11 các phím đồng thời để mở Microsoft Visual Basic cho các ứng dụng cửa sổ.
2. bên trong Microsoft Visual Basic cho các ứng dụng cửa sổ, nhấp Chèn > Mô-đun. Sau đó sao chép và dán mã VBA bên dưới vào Mã cửa sổ. Xem ảnh chụp màn hình:
Mã VBA: Lưu trang tính dưới dạng tệp PDF và gửi qua email dưới dạng tệp đính kèm
Sub Saveaspdfandsend()
Dim xSht As Worksheet
Dim xFileDlg As FileDialog
Dim xFolder As String
Dim xYesorNo As Integer
Dim xOutlookObj As Object
Dim xEmailObj As Object
Dim xUsedRng As Range
Set xSht = ActiveSheet
Set xFileDlg = Application.FileDialog(msoFileDialogFolderPicker)
If xFileDlg.Show = True Then
xFolder = xFileDlg.SelectedItems(1)
Else
MsgBox "You must specify a folder to save the PDF into." & vbCrLf & vbCrLf & "Press OK to exit this macro.", vbCritical, "Must Specify Destination Folder"
Exit Sub
End If
xFolder = xFolder + "\" + xSht.Name + ".pdf"
'Check if file already exist
If Len(Dir(xFolder)) > 0 Then
xYesorNo = MsgBox(xFolder & " already exists." & vbCrLf & vbCrLf & "Do you want to overwrite it?", _
vbYesNo + vbQuestion, "File Exists")
On Error Resume Next
If xYesorNo = vbYes Then
Kill xFolder
Else
MsgBox "if you don't overwrite the existing PDF, I can't continue." _
& vbCrLf & vbCrLf & "Press OK to exit this macro.", vbCritical, "Exiting Macro"
Exit Sub
End If
If Err.Number <> 0 Then
MsgBox "Unable to delete existing file. Please make sure the file is not open or write protected." _
& vbCrLf & vbCrLf & "Press OK to exit this macro.", vbCritical, "Unable to Delete File"
Exit Sub
End If
End If
Set xUsedRng = xSht.UsedRange
If Application.WorksheetFunction.CountA(xUsedRng.Cells) <> 0 Then
'Save as PDF file
xSht.ExportAsFixedFormat Type:=xlTypePDF, Filename:=xFolder, Quality:=xlQualityStandard
'Create Outlook email
Set xOutlookObj = CreateObject("Outlook.Application")
Set xEmailObj = xOutlookObj.CreateItem(0)
With xEmailObj
.Display
.To = ""
.CC = ""
.Subject = xSht.Name + ".pdf"
.Attachments.Add xFolder
If DisplayEmail = False Then
'.Send
End If
End With
Else
MsgBox "The active worksheet cannot be blank"
Exit Sub
End If
End Sub
3. Nhấn nút F5 phím để chạy mã. bên trong Xem hộp thoại, vui lòng chọn một thư mục để lưu tệp PDF này, sau đó nhấp vào OK .
Chú ý:
Dễ dàng lưu một trang tính hoặc nhiều trang tính dưới dạng các tệp PDF riêng biệt cùng một lúc:
Mô hình Chia sổ làm việc tiện ích của Kutools cho Excel có thể giúp bạn dễ dàng lưu một trang tính hoặc nhiều trang tính dưới dạng các tệp PDF riêng biệt cùng một lúc như minh họa bên dưới. Tải xuống và thử ngay bây giờ! (30-ngày đường mòn miễn phí)
Các bài liên quan:
- Làm cách nào để lưu tên tệp Excel với dấu thời gian?
- Làm thế nào để sử dụng chức năng Save As để tự động ghi đè lên tệp hiện có trong Excel?
- Làm cách nào để lưu, xuất nhiều / tất cả các trang tính thành tệp csv hoặc tệp văn bản riêng biệt trong Excel?
- Làm cách nào để tắt hoặc không cho phép tùy chọn Lưu & Lưu dưới dạng trong Excel?
- Làm cách nào để tắt tính năng lưu sổ làm việc nhưng chỉ cho phép lưu như trong Excel?
Các công cụ năng suất văn phòng tốt nhất
Kutools cho Excel giải quyết hầu hết các vấn đề của bạn và tăng 80% năng suất của bạn
- Tái sử dụng: Chèn nhanh công thức phức tạp, biểu đồ và bất cứ thứ gì bạn đã sử dụng trước đây; Mã hóa ô với mật khẩu; Tạo danh sách gửi thư và gửi email ...
- Thanh siêu công thức (dễ dàng chỉnh sửa nhiều dòng văn bản và công thức); Bố cục đọc (dễ dàng đọc và chỉnh sửa số lượng ô lớn); Dán vào Dải ô đã Lọchữu ích. Cảm ơn !
- Hợp nhất các ô / hàng / cột mà không làm mất dữ liệu; Nội dung phân chia ô; Kết hợp các hàng / cột trùng lặp... Ngăn chặn các ô trùng lặp; So sánh các dãyhữu ích. Cảm ơn !
- Chọn trùng lặp hoặc duy nhất Hàng; Chọn hàng trống (tất cả các ô đều trống); Tìm siêu và Tìm mờ trong Nhiều Sổ làm việc; Chọn ngẫu nhiên ...
- Bản sao chính xác Nhiều ô mà không thay đổi tham chiếu công thức; Tự động tạo tài liệu tham khảo sang Nhiều Trang tính; Chèn Bullets, Hộp kiểm và hơn thế nữa ...
- Trích xuất văn bản, Thêm Văn bản, Xóa theo Vị trí, Xóa không gian; Tạo và In Tổng số phân trang; Chuyển đổi giữa nội dung ô và nhận xéthữu ích. Cảm ơn !
- Siêu lọc (lưu và áp dụng các lược đồ lọc cho các trang tính khác); Sắp xếp nâng cao theo tháng / tuần / ngày, tần suất và hơn thế nữa; Bộ lọc đặc biệt bằng cách in đậm, in nghiêng ...
- Kết hợp Workbook và WorkSheets; Hợp nhất các bảng dựa trên các cột chính; Chia dữ liệu thành nhiều trang tính; Chuyển đổi hàng loạt xls, xlsx và PDFhữu ích. Cảm ơn !
- Hơn 300 tính năng mạnh mẽ. Hỗ trợ Office / Excel 2007-2021 và 365. Hỗ trợ tất cả các ngôn ngữ. Dễ dàng triển khai trong doanh nghiệp hoặc tổ chức của bạn. Đầy đủ tính năng Dùng thử miễn phí 30 ngày. Bảo đảm hoàn lại tiền trong 60 ngày.

Tab Office mang lại giao diện Tab cho Office và giúp công việc của bạn trở nên dễ dàng hơn nhiều
- Cho phép chỉnh sửa và đọc theo thẻ trong Word, Excel, PowerPoint, Publisher, Access, Visio và Project.
- Mở và tạo nhiều tài liệu trong các tab mới của cùng một cửa sổ, thay vì trong các cửa sổ mới.
- Tăng 50% năng suất của bạn và giảm hàng trăm cú nhấp chuột cho bạn mỗi ngày!



















































