Menu

App script quản lý rủi ro cho cá nhân & doanh nghiệp với báo cáo chuẩn định dạng biểu đồ

Tự động hóa tạo file Excel mới với dữ liệu được chọn từ file gốc bằng Python

Mai Tuệ Yêu 03/04/2026 23:40 212 lượt xem 1 trả lời

Chào các anh em, mình có một bài toán nhỏ muốn chia sẻ và cũng là nhờ mọi người xem có cách nào tối ưu hơn không.

Tình hình là mình có một file Excel nguồn chứa rất nhiều dữ liệu (hàng chục nghìn dòng). Bây giờ mình muốn tạo ra một file Excel mới, nhưng chỉ chứa những dòng dữ liệu thỏa mãn một vài điều kiện nhất định, ví dụ như chỉ lấy những đơn hàng có trạng thái 'Hoàn thành'ngày đặt hàng trong tháng 10/2023.

Trước đây, mình toàn làm thủ công là lọc trên file gốc rồi copy-paste sang file mới. Tuy nhiên, việc này rất tốn thời gian và dễ sai sót, đặc biệt khi file nguồn có quá nhiều dữ liệu.

Gần đây, mình có mày mò học Python và thấy có thể dùng thư viện pandas để giải quyết vấn đề này một cách tự động. Ý tưởng của mình là:

  • Đọc file Excel nguồn vào một DataFrame của pandas.
  • Áp dụng các bộ lọc để chọn ra những dòng dữ liệu mong muốn.
  • Tạo một DataFrame mới từ dữ liệu đã lọc.
  • Xuất DataFrame mới này ra một file Excel mới.

Code cơ bản của mình trông như thế này:

import pandas as pd

# Đọc file Excel nguồn
df_nguon = pd.read_excel('du_lieu_nguon.xlsx')

# Lọc dữ liệu theo điều kiện
df_loc = df_nguon[(df_nguon['Trạng thái'] == 'Hoàn thành') & (df_nguon['Ngày đặt hàng'] >= '2023-10-01') & (df_nguon['Ngày đặt hàng'] 
                
0

Hay quá bạn ơi! Cách làm thủ công đúng là tốn thời gian thật. Mình cũng hay gặp tình huống tương tự. Với yêu cầu lọc dữ liệu theo điều kiện rồi xuất file mới, bạn đã nghĩ đến việc dùng thư viện pandas trong Python chưa? Nó xử lý dữ liệu dạng bảng (như Excel) rất mạnh mẽ. Chỉ vài dòng code là có thể đọc file gốc, lọc theo điều kiện (trạng thái 'Hoàn thành', ngày tháng) và lưu sang file mới. Không biết bạn đã thử dùng pandas chưa, có cần mình chia sẻ một đoạn code mẫu không?

2

Bạn cần đăng nhập để trả lời chủ đề này.

Đăng nhập Đăng ký