Khóavàbảovệnhữngôcóchứacôngthức Ngày gửi bài: 12/11/2008 Số lượt đọc: 141 Chiêu này giúp bạn cho phép người khác thay đổi các ôcóchứa dữ liệu, nhưng cấm họ thay đổi các ôchứacông thức. Bạn cũng có thể bảovệ các ôcóchứacôngthức mà không cần phải bảovệ toàn bộ trang tính của bạn. Khi tạo một bảng tính, thường chúng ta sẽ phải dùng đến một số công thức, và khi chia sẻ bảng tính cho mọi người, có thể bạn muốn rằng, không ai có thể can thiệp (xóa, sửa .) những vào nhữngôcóchứacông thức. Cách dễ nhất là cũng phổ biến nhất là Protect (bảo vệ) bảng tính. Tuy nhiên, Protect bảng tính không chỉ ngăn không cho can thiệp vào các ôchứacông thức, mà nó không cho can thiệp vào tất cả, nghĩa là không ai có thể làm gì bảng tính của bạn. Đôi khi, bạn lại không muốn như vậy, bạn chỉ muốn bảovệ các ôchứacôngthức thôi, còn nhữngôchứa dữ liệu thì không. Có ba giải pháp để thực hiện điều này: Khóanhữngôchứacông thức, sử dụng chức năng Data-validation cho các ôchứacông thức, và tự động bật tắt chức năng bảo vệ. Khóa các ôchứacôngthức Theo mặc định, tất cả các ô trong bảng tính đều được khóa (locked), tuy nhiên, nó chẳng có tác dụng gì trừ phi bạn áp dụng lệnh Protect bảng tính. Đây là cách dễ nhất để áp dụng lệnh Protect cho bảng tính, nhưng chỉ nhữngôchứacôngthức thì mới bị khóa, và được bảo vệ: Chọn toàn bộ bảng tính, bằng cách nhấn Ctrl+A, hoặc nhấn vào cái ô vuông nằm ở giao điểm của cột A và hàng 1. Rồi nhấn nút phải chuột và chọn Format Cells, rồi trong tab Protection, bỏ đánh dấu ở tùy chọn Locked, rồi nhấn OK: Mở khóa (Unlock) toàn bộ bảng tính bằng cách bỏ tùy chọn Locked Sau đó, bạn chọn đại một ô nào đó, chọn Home ➝ Find & Select ➝ Go To Special [E2003: Edit | Go To… | Special]; hoặc nhấn Ctrl+G hay F5 rồi nhấn vào nút Special Hộp thoại sau đây sẽ mở ra: Dùng hộp thoại Go To Special để chọn các ôcóchứacôngthức Trong hộp thoại đó, bạn nhấn vào tùy chọn Formulas, và nếu cần thiết thì chọn hoặc không chọn thêm 4 ô nhỏ ở dưới (liệt kê các loại công thức, mặc định thì cả 4 ô này đều được chọn), và nhấn OK. Sau đó, bạn mở lại hộp thoại Format Cells đã nói ở trên, nhưng lần này thì bạn đánh dấu vào tùy chọn Locked, và nếu bạn thích ẩn luôn côngthức (không cho thấy) thì đánh dấu vào tùy chọn Hidden, nhấn OK. Việc cuối cùng là Protect bảng tính: Chọn Home trên Ribbon, nhấn vào Formattrong nhóm Cells, rồi nhấn vào Protect Sheet .; hoặc chọn Reviewtrên Ribbon, rồi nhấn vào Protect Sheet [E2003: Tools | Protection | Protect Worksheet]: Chọn Protect Sheet từ Home Chọn Protect Sheet từ Review Trong hộp thoại Protect Sheet, bỏ đánh dấu ở tùy chọn Select locked cells, chỉ cho phép Select unlocked cells (chọn nhữngô không khóa), và nhập vào một password, nếu cần thiết: Bỏ tùy chọn Select locked cells trong hộp thoại Protect Sheet Vậy là xong. Từ bây giờ, nhữngôchứacôngthức của bạn sẽ được bảo vệ, có thể không xem thấy được nếu bạn đã chọn Hidden, bạn không lo nhữngcôngthức này bị can thiệp nữa. Sử dụng Data-validation Sử dụng Data-validation, chỉ là đơn giản không cho ghi đè vào nhữngôcóchứacông thức, nghĩa là không cho sửa công thức. Tuy nhiên, phương pháp này chỉ phòng ngừa cho chính bạn, nghĩa là tránh việc táy máy sửa lại cái gì đó trong nhữngôchứacông thức, chứ thật ra, mặc dù đã được "Validation", bạn vẫn có thể xóa công thức, hoặc dán vào nhữngô đó bất kỳ dữ liệu nào bạn thích . Nói chung nó không bảovệ được gì nhiều. Nhưng cũng xin nói sơ qua về phương pháp này: Để thực hiện, bạn hãy chọn nhữngôchứaôcôngthức bằng chức năng Go To Specials mà tôi đã nói ở trên. Rồi, với nhữngôchứacôngthức đang được chọn, bạn gọi Data Validation từ menu Data trên Ribbon [E2003: Data | Validation]. Trong hộp thoại này, chọn tab Settings, chọn Custom cho khung Allow, và nhập côngthức này: =" " vào khung Formula, rồi nhấn OK, như hình sau: Sử dụng Data Validation để bảovệnhữngôchứacôngthức Kể từ đây, mỗi khi bạn nhập bất kỳ thứ gì vào trong nhữngôchứacông thức, hoặc bạn muốn sửa lại công thức, sẽ có một cảnh báo xuất hiện, ngăn không cho bạn nhập vào. Xin nhắc lại, phương pháp này không cấm việc xóa hẳn công thức, cũng như dán đè thứ gì đó vào nhữngôchứacông thức. Tự động bật tắt chức năng bảovệ Phương pháp này, sẽ tự động bật chức năng bảovệ bảng tính (Protect) mỗi khi bạn chọn một ô đã được khóa (locked), nhưng nó cũng sẽ tự động tắt chức năng bảovệ khi bạn chọn một ô không bị khóa. Để bắt đầu, bạn hãy chắc chắn rằng nhữngô bạn muốn bảovệ (ô chứacông thức) đã được khóa, còn nhữngô không cần bảovệ thì không bị khóa, như tôi đã trình bày ở phương pháp thứ nhất. Sau đó, bạn nhấn Alt+F11, nhấn vào Sheet mà bạn muốn bảovệ các ô đã khóaở trong đó, rồi nhập vào trong khung soạn thảo đoạn code sau đây: Nếu không cần đến password, bạn không cần dùng đoạn Password:="Secret", hoặc nếu muốn Password là thứ gì khác, bạn sửa lại chữ Secretbằng cái bạn muốn. Nếu bạn lo rằng người ta có thể vào trong khung soạn thảo VBA để xem password, bạn có thể bảovệ các code này (không cho xem) bằng cách chọn Tools ➝ VBAProject Properties, chọn tab Properties, chọn Lock Project for Viewing, và nhập vào một password. Tuy nhiên, phương pháp này cũng không hoạt động hoàn hảo, mặc dù nó cũng giúp bạn được phần nào việc bảovệ các công thức. Từ khóa Target được sử dụng trong đoạn code sẽ chỉ để tham chiếu đến ô đang "active" ngay tại thời điểm nó được chọn (xin nói thêm, cho dù bạn chọn một dãy, nhưng trong dãy đó, chỉ có một ô "active" mà thôi, là ô đang có màu khác với nhữngô còn lại). Vì lý do này, nếu một người nào đó chọn một dãy các ô (với ô "active" không bị khóa), thì người đó có thể xóa toàn bộ dãy ô này, bởi vì khi đó thì chức năng Unprotect đã được tự động bật! . bạn hãy chắc chắn rằng những ô bạn muốn bảo vệ (ô chứa công thức) đã được khóa, còn những ô không cần bảo vệ thì không bị khóa, như tôi đã trình bày ở phương. liệu, nhưng cấm họ thay đổi các ô chứa công thức. Bạn cũng có thể bảo vệ các ô có chứa công thức mà không cần phải bảo vệ toàn bộ trang tính của bạn. Khi