Tìm hiểu cách sử dụng macro Excel để tự động hóa các công việc tẻ nhạt

Một trong những chức năng mạnh mẽ hơn, nhưng hiếm khi được sử dụng của Excel là khả năng rất dễ dàng tạo các tác vụ tự động và logic tùy chỉnh trong macro. Macro cung cấp một cách lý tưởng để tiết kiệm thời gian cho các tác vụ có thể đoán trước, lặp đi lặp lại cũng như chuẩn hóa các định dạng tài liệu - nhiều lần mà không cần phải viết một dòng mã.

Nếu bạn muốn biết macro là gì hoặc cách thực sự tạo chúng, không vấn đề gì - chúng tôi sẽ hướng dẫn bạn toàn bộ quy trình.

Ghi chú:quy trình tương tự sẽ hoạt động trong hầu hết các phiên bản của Microsoft Office. Ảnh chụp màn hình có thể hơi khác một chút.

Macro là gì?

Macro Microsoft Office (vì chức năng này áp dụng cho một số Ứng dụng MS Office) chỉ đơn giản là mã Visual Basic for Applications (VBA) được lưu bên trong tài liệu. Để so sánh một cách tương tự, hãy nghĩ về một tài liệu là HTML và một macro là Javascript. Giống như cách mà Javascript có thể thao tác HTML trên một trang web, macro có thể thao tác một tài liệu.

Macro cực kỳ mạnh mẽ và có thể làm được khá nhiều điều mà trí tưởng tượng của bạn có thể gợi ra. Dưới dạng một danh sách ngắn (rất) các chức năng bạn có thể thực hiện với macro:

  • Áp dụng kiểu và định dạng.
  • Thao tác dữ liệu và văn bản.
  • Giao tiếp với các nguồn dữ liệu (cơ sở dữ liệu, tệp văn bản, v.v.).
  • Tạo tài liệu hoàn toàn mới.
  • Bất kỳ sự kết hợp nào, theo thứ tự bất kỳ, của bất kỳ điều nào ở trên.

Tạo Macro: Giải thích bằng ví dụ

Chúng tôi bắt đầu với tệp CSV nhiều loại vườn của bạn. Không có gì đặc biệt ở đây, chỉ là một bộ số 10 × 20 từ 0 đến 100 với cả tiêu đề hàng và cột. Mục tiêu của chúng tôi là tạo ra một bảng dữ liệu có định dạng tốt, dễ trình bày, bao gồm các tổng số tóm tắt cho mỗi hàng.

Như chúng tôi đã nêu ở trên, macro là mã VBA, nhưng một trong những điều thú vị về Excel là bạn có thể tạo / ghi chúng mà không cần mã hóa - như chúng tôi sẽ làm ở đây.

Để tạo macro, hãy đi tới Xem> Macro> Ghi Macro.

Gán tên cho macro (không có khoảng trắng) và bấm OK.

Khi điều này được thực hiện, tất cả hành động của bạn được ghi lại - mọi thay đổi ô, hành động cuộn, thay đổi kích thước cửa sổ, bạn đặt tên cho nó.

Có một số chỗ cho biết Excel đang ở chế độ ghi. Một là xem menu Macro và lưu ý rằng Stop Recording đã thay thế tùy chọn cho Record Macro.

Cái còn lại ở góc dưới cùng bên phải. Biểu tượng ‘dừng’ cho biết nó đang ở chế độ macro và nhấn vào đây sẽ dừng ghi (tương tự như vậy, khi không ở chế độ ghi, biểu tượng này sẽ là nút Ghi Macro, bạn có thể sử dụng thay vì vào menu Macro).

Bây giờ chúng tôi đang ghi lại macro của mình, hãy áp dụng các tính toán tóm tắt của chúng tôi. Đầu tiên hãy thêm các tiêu đề.

Tiếp theo, áp dụng các công thức thích hợp (tương ứng):

  • = SUM (B2: K2)
  • = AVERAGE (B2: K2)
  • = MIN (B2: K2)
  • = MAX (B2: K2)
  • = MEDIAN (B2: K2)

Bây giờ, đánh dấu tất cả các ô tính toán và kéo độ dài của tất cả các hàng dữ liệu của chúng tôi để áp dụng các phép tính cho mỗi hàng.

Khi điều này được thực hiện, mỗi hàng sẽ hiển thị các bản tóm tắt tương ứng của chúng.

Bây giờ, chúng tôi muốn lấy dữ liệu tóm tắt cho toàn bộ trang tính, vì vậy chúng tôi áp dụng thêm một số phép tính:

Tương ứng:

  • = SUM (L2: L21)
  • = AVERAGE (B2: K21) *Điều này phải được tính toán trên tất cả dữ liệu vì giá trị trung bình của hàng trung bình không nhất thiết phải bằng giá trị trung bình của tất cả các giá trị.
  • = MIN (N2: N21)
  • = MAX (O2: O21)
  • = MEDIAN (B2: K21) * Được tính toán trên tất cả các dữ liệu cho cùng một lý do như trên.

Bây giờ các tính toán đã được thực hiện, chúng tôi sẽ áp dụng kiểu và định dạng. Trước tiên, hãy áp dụng định dạng số chung cho tất cả các ô bằng cách thực hiện Chọn tất cả (Ctrl + A hoặc nhấp vào ô giữa tiêu đề hàng và cột) và chọn biểu tượng “Kiểu dấu phẩy” trong menu Trang chủ.

Tiếp theo, áp dụng một số định dạng trực quan cho cả tiêu đề hàng và cột:

  • Dũng cảm.
  • Căn giữa.
  • Màu nền.

Và cuối cùng, áp dụng một số kiểu cho các tổng.

Khi tất cả hoàn tất, đây là bảng dữ liệu của chúng tôi trông như thế nào:

Vì chúng tôi hài lòng với kết quả, hãy dừng việc ghi macro.

Xin chúc mừng - bạn vừa tạo macro Excel.

Để sử dụng macro mới được ghi của chúng tôi, chúng tôi phải lưu Sổ làm việc Excel của mình ở định dạng tệp hỗ trợ macro. Tuy nhiên, trước khi làm điều đó, trước tiên chúng ta cần xóa tất cả dữ liệu hiện có để nó không được nhúng vào mẫu của chúng ta (ý tưởng là mỗi khi chúng ta sử dụng mẫu này, chúng ta sẽ nhập dữ liệu cập nhật nhất).

Để làm điều này, hãy chọn tất cả các ô và xóa chúng.

Với dữ liệu hiện đã bị xóa (nhưng macro vẫn được bao gồm trong tệp Excel), chúng tôi muốn lưu tệp dưới dạng tệp mẫu hỗ trợ macro (XLTM). Điều quan trọng cần lưu ý là nếu bạn lưu tệp này dưới dạng tệp mẫu chuẩn (XLTX) thì macro sẽ không phải có thể được chạy từ nó. Ngoài ra, bạn có thể lưu tệp dưới dạng tệp mẫu kế thừa (XLT), tệp này sẽ cho phép chạy các macro.

Khi bạn đã lưu tệp dưới dạng mẫu, hãy tiếp tục và đóng Excel.

Sử dụng Macro Excel

Trước khi trình bày về cách chúng ta có thể áp dụng macro mới được ghi lại này, điều quan trọng là phải đề cập đến một số điểm về macro nói chung:

  • Macro có thể độc hại.
  • Xem điểm trên.

Mã VBA thực sự khá mạnh và có thể thao tác các tệp bên ngoài phạm vi của tài liệu hiện tại. Ví dụ: macro có thể thay đổi hoặc xóa các tệp ngẫu nhiên trong thư mục Tài liệu của tôi. Do đó, điều quan trọng là phải đảm bảo rằng bạn chỉ có chạy macro từ các nguồn đáng tin cậy.

Để sử dụng macro định dạng dữ liệu của chúng tôi, hãy mở tệp Mẫu Excel đã được tạo ở trên. Khi bạn làm điều này, giả sử bạn đã bật cài đặt bảo mật tiêu chuẩn, bạn sẽ thấy một cảnh báo trên đầu sổ làm việc cho biết rằng macro đã bị vô hiệu hóa. Vì chúng tôi tin tưởng một macro do chính chúng tôi tạo, hãy nhấp vào nút "Bật nội dung".

Tiếp theo, chúng tôi sẽ nhập tập dữ liệu mới nhất từ ​​CSV (đây là nguồn trang tính được sử dụng để tạo macro của chúng tôi).

Để hoàn tất việc nhập tệp CSV, bạn có thể phải đặt một vài tùy chọn để Excel có thể diễn giải tệp đó một cách chính xác (ví dụ: dấu phân cách, có tiêu đề, v.v.).

Sau khi dữ liệu của chúng tôi được nhập, chỉ cần đi tới trình đơn Macro (trong tab Chế độ xem) và chọn Chế độ xem Macro.

Trong hộp thoại kết quả, chúng ta thấy macro "FormatData" mà chúng ta đã ghi ở trên. Chọn nó và nhấp vào Chạy.

Sau khi chạy, bạn có thể thấy con trỏ nhảy xung quanh trong giây lát, nhưng khi chạy, bạn sẽ thấy dữ liệu đang được thao tác chính xác như chúng tôi đã ghi lại. Khi tất cả được nói và hoàn thành, nó sẽ giống như bản gốc của chúng ta - ngoại trừ dữ liệu khác.

Nhìn dưới mái che: Điều gì làm cho Macro hoạt động

Như chúng tôi đã đề cập một vài lần, một macro được điều khiển bởi mã Visual Basic for Applications (VBA). Khi bạn "ghi lại" một macro, Excel thực sự đang dịch mọi thứ bạn làm thành các hướng dẫn VBA tương ứng của nó. Nói một cách đơn giản - bạn không phải viết bất kỳ mã nào vì Excel đang viết mã cho bạn.

Để xem mã làm cho macro của chúng tôi chạy, từ hộp thoại Macro, hãy nhấp vào nút Chỉnh sửa.

Cửa sổ mở ra hiển thị mã nguồn đã được ghi lại từ các hành động của chúng tôi khi tạo macro. Tất nhiên, bạn có thể chỉnh sửa mã này hoặc thậm chí tạo macro mới hoàn toàn bên trong cửa sổ mã. Mặc dù hành động ghi được sử dụng trong bài viết này có thể sẽ phù hợp với hầu hết các nhu cầu, nhưng các hành động tùy chỉnh cao hơn hoặc các hành động có điều kiện sẽ yêu cầu bạn chỉnh sửa mã nguồn.

Lấy ví dụ của chúng tôi xa hơn một bước…

Theo giả thuyết, giả sử tệp dữ liệu nguồn của chúng tôi, data.csv, được tạo ra bởi một quy trình tự động luôn lưu tệp vào cùng một vị trí (ví dụ: C: \ Data \ data.csv luôn là dữ liệu mới nhất). Quá trình mở và nhập tệp này cũng có thể dễ dàng thực hiện thành một macro:

  1. Mở tệp Mẫu Excel có chứa macro “Dữ liệu định dạng” của chúng tôi.
  2. Ghi lại một macro mới có tên là “LoadData”.
  3. Với ghi macro, hãy nhập tệp dữ liệu như bạn thường làm.
  4. Sau khi dữ liệu được nhập, hãy dừng ghi macro.
  5. Xóa tất cả dữ liệu ô (chọn tất cả rồi xóa).
  6. Lưu mẫu đã cập nhật (nhớ sử dụng định dạng mẫu hỗ trợ macro).

Khi điều này được thực hiện, bất cứ khi nào mẫu được mở, sẽ có hai macro - một macro tải dữ liệu của chúng tôi và macro định dạng nó.

Nếu bạn thực sự muốn chỉnh sửa một chút mã, bạn có thể dễ dàng kết hợp các hành động này thành một macro duy nhất bằng cách sao chép mã được tạo từ “LoadData” và chèn nó vào đầu mã từ “FormatData”.

Tải xuống Mẫu này

Để thuận tiện cho bạn, chúng tôi đã bao gồm cả mẫu Excel được tạo trong bài viết này cũng như một tệp dữ liệu mẫu để bạn sử dụng.

Tải xuống Mẫu Macro Excel từ How-To Geek


$config[zx-auto] not found$config[zx-overlay] not found