⏱️2 min read · 319 words

البانداهي مكتبة Python الأكثر استخدامًا لتحليل البيانات في عام 2026. سواء كنت تقوم بتنظيف ملفات CSV، أو تجميع بيانات المبيعات، أو إعداد مجموعات البيانات للتعلم الآلي، فإن Pandas هي الأداة. يغطي هذا البرنامج التعليمي العمليات الأساسية التي يحتاجها كل متخصص في البيانات.
📋 Table of Contents
تثبيت واستيراد
pip install pandas numpy
import pandas as pd
import numpy as np
print(pd.__version__) # 2.2+
إنشاء إطارات البيانات
# From dict
df = pd.DataFrame({
'name': ['Alice', 'Bob', 'Carol', 'Dave'],
'age': [25, 30, 35, 28],
'salary': [70000, 85000, 92000, 78000],
'dept': ['Eng', 'Mktg', 'Eng', 'HR'],
})
# From CSV
df = pd.read_csv('data.csv')
# From JSON
df = pd.read_json('data.json')
print(df.head()) # First 5 rows
print(df.info()) # Column types and nulls
print(df.describe()) # Stats summary
تحديد البيانات
# Select column
df['name'] # Series
df[['name', 'salary']] # DataFrame
# Select rows by condition
df[df['salary'] > 80000]
df[(df['dept'] == 'Eng') & (df['age'] < 35)]
# iloc — by position
df.iloc[0] # First row
df.iloc[1:3] # Rows 1-2
# loc — by label
df.loc[df['dept'] == 'Eng', ['name', 'salary']]
بيانات التنظيف
# Check nulls
df.isnull().sum()
# Drop rows with any null
df.dropna(inplace=True)
# Fill nulls
df['salary'].fillna(df['salary'].mean(), inplace=True)
# Remove duplicates
df.drop_duplicates(inplace=True)
# Rename columns
df.rename(columns={'name': 'full_name'}, inplace=True)
# Change dtype
df['age'] = df['age'].astype(int)
التجميع والتجميع
# Group by department, get stats
summary = df.groupby('dept').agg(
count=('name', 'count'),
avg_salary=('salary', 'mean'),
max_salary=('salary', 'max'),
).reset_index()
print(summary)
# dept count avg_salary max_salary
# Eng 2 81000.0 92000
# HR 1 78000.0 78000
# Mktg 1 85000.0 85000
دمج إطارات البيانات
# Two DataFrames
employees = pd.DataFrame({'emp_id': [1,2,3], 'name': ['Alice','Bob','Carol']})
salaries = pd.DataFrame({'emp_id': [1,2,4], 'salary': [70000,85000,60000]})
# Inner join (only matching)
merged = employees.merge(salaries, on='emp_id', how='inner')
# Left join (keep all employees)
merged = employees.merge(salaries, on='emp_id', how='left')
تطبيق الوظائف
# Apply function to column
df['salary_band'] = df['salary'].apply(
lambda s: 'High' if s > 90000 else ('Mid' if s > 75000 else 'Low')
)
# Apply to multiple columns
df[['age','salary']].apply(lambda col: col / col.max())
# Vectorized operations (faster than apply)
df['salary_k'] = df['salary'] / 1000
df['senior'] = df['age'] >= 30
نتائج التصدير
df.to_csv('output.csv', index=False)
df.to_excel('output.xlsx', index=False)
df.to_json('output.json', orient='records')
الخلاصة
تتعامل Pandas مع 95% من مهام معالجة البيانات في العالم الحقيقي. ماسترgroupby,mergeوالعمليات الموجهة وستقوم بمعالجة ملايين الصفوف في ثوانٍ. ادمجها مع Matplotlib أو Plotly للتصور، أو قم بتسليم البيانات المنظفة إلى scikit-learn لتعلم الآلة.
🔗 Share this article
✍️ Leave a Comment