Python Pandas `or` Operatörü ile Şartları Birleştirme

Giriş: Python Pandas ve Mantıksal Operatörler

Pandas, Python programlama dilinde veri analizi ve manipülasyonu için en popüler kütüphanedir. Geliştiricilere veri üzerindeki işlemleri kolaylaştıran gelişmiş veri yapıları ve analiz araçları sunar. Pandas kullanarak veri analizi yaparken sıkça karşılaşılabilecek bir durum, koşullu filtrelemelerdir. Verilerinizi belirli kriterlere göre süzerken, mantıksal operatörlerden yararlanmak, zengin veri setlerindeki alt kümeleri bulmanın etkili bir yoludur. Bu yazıda, özellikle ‘or’ operatörünün nasıl kullanıldığını ve Pandas’ta koşulları birleştirmek için nasıl etkili bir şekilde entegre edildiğini inceleyeceğiz.

‘or’ Operatörünün Temel Kullanımı

‘or’ operatörü, iki veya daha fazla koşuldan en az birinin true (doğru) olmasını sağlamak için kullanılır. Python’da mantıksal operatörleri kullanarak, verilerinizi koşullara göre filtrelemek için karşılaştırma ifadeleri oluşturabilirsiniz. Pandas kütüphanesindeki DataFrame’ler üzerinde çalışırken, ‘or’ operatörünü kullanarak birden fazla koşulu birleştirmek, karmaşık veri analizlerini daha basit hale getirir.

Pandas’ta ‘or’ operatörünü kullanmak için genellikle ‘&’ ve ‘|’ sembollerini kullanmanız gereklidir. Ancak, bu operatörlerin doğru bir şekilde kullanılabilmesi için koşul ifadelerinizin parantez içerisine alınması gerektiğini akılda tutmak önemlidir. Bu, Python’un erişim önceliğini doğru bir şekilde anlamak için gereklidir. Örneğin, eğer bir DataFrame’e sahipseniz ve belirli sütunlarda koşul sağlıyorsanız, bu koşulları birleştirerek verilerinizi filtreleyebilirsiniz.

Pandas DataFrame Oluşturma

Öncelikle, örnek bir DataFrame oluşturarak başlayabiliriz. Bu DataFrame, fiktif bir müşteri bilgileri listesi olsun. Her müşteri için yaş, şehir ve alışveriş harcamasını içeren birkaç veri noktası içerecektir:

import pandas as pd

# Örnek müşteri verisi oluşturma
data = {
    'isim': ['Ali', 'Ayşe', 'Mehmet', 'Fatma'],
    'yaş': [24, 30, 22, 35],
    'şehir': ['İstanbul', 'Ankara', 'İstanbul', 'İzmir'],
    'harcama': [150, 200, 50, 300]
}

musteriler = pd.DataFrame(data)
print(musteriler)

Yukarıdaki kod parçasında, ‘musteriler’ isimli bir DataFrame oluşturduk. Bu DataFrame, isim, yaş, şehir ve harcama gibi dört temel sütunu içermektedir. Şimdi, bu DataFrame üzerinde ‘or’ operatörünü kullanarak bazı koşullara bakalım.

‘or’ Operatörü ile Filtreleme

Örneğin, 30 yaşından büyük olan veya İstanbul’da yaşayan müşterileri filtrelemek isteyelim. Bunun için, yaş ve şehir gibi iki koşulu birleştireceğiz:

filtered_musteriler = musteri[(musteriler['yaş'] > 30) | (musteriler['şehir'] == 'İstanbul')]
print(filtered_musteriler)

Yukarıdaki filtreleme işleminde gördüğümüz gibi, ‘or’ operatörünü kullanarak iki koşulu birleştirdik. 30 yaşından büyük olan ya da İstanbul’da bulunan tüm müşterileri listeleme imkanına sahip olduk. Sonuç olarak, bu tür bir mantıksal filtreleme, veri setlerindeki hedef kitleyi belirlemek için son derece faydalıdır.

Uygulamalı Örnek: Ekstra Koşulların Eklenmesi

Pandas, veri analizi yaparken esnekliğe önem verir. Yukarıdaki örnekte yalnızca iki koşulu inceledik; ancak daha fazla koşul ekleyerek filtrelemeyi daha karmaşık hale getirebiliriz. Farz edelim ki, yalnızca 100 TL’den fazla harcama yapan müşterileri hedef almak istiyoruz. Bu durumda, ‘or’ operatörünün yanı sıra başka bir koşul ekleyebiliriz:

ekstra_filtered = musteri[(musteriler['yaş'] > 30) | (musteriler['şehir'] == 'İstanbul')] 
                  & (musteriler['harcama'] > 100)
print(ekstra_filtered)

Bu filtrelemede, hem yaş ve şehir koşulları hem de harcama koşulunu birleştirdik. Böylece verilerimizi birden fazla kriter altında inceleyebiliriz. Bu tür bir yaklaşım, özellikle büyük ve karmaşık veri setleriyle çalışırken oldukça faydalıdır. Hedef kitle analizinde daha hassas sonuçlar elde etmemizi sağlar.

Hata Ayıklama ve Sık Karşılaşılan Problemler

Pandas’ta koşul ifadeleri oluştururken, bazen beklenmedik hatalarla karşı karşıya kalabiliriz. Bu hataların en yaygın sebeplerinden biri, koşul ifadelerini parantezlememektir. Python, koşul ifadelerinin önceliğini anlamakta zorlanabilir:

try:
    hatalı_filtered = musteri[musteriler['yaş'] > 30 | musteriler['şehir'] == 'İstanbul']
except Exception as e:
    print(f'Hata: {e}')

Yukarıdaki örnekte, ‘or’ operatörü doğru bir şekilde parantez içerisinde değilse, Python hata verecektir. Bu nedenle koşul ifadeleri oluştururken parantez kullanımına dikkat etmeniz gerekir. Özellikle karmaşık koşullarda, ifadelerin açık olduğu bir yapı kurmak, kodun okunabilirliğini artırırken, hata olasılığını da azaltır.

Performans Üzerindeki Etkiler

Bir veri setindeki koşulları filtrelerken performans da önemlidir. Çok büyük veri setlerinde filtreleme yaparken, koşul ifadelerinin karmaşıklığı, işlem sürelerini etkileyebilir. Bu nedenle, mümkün olduğunca açık ve basit koşullar kullanmak her zaman faydalı olacaktır. Ek olarak, verilerinizi filtreledikten sonra, verinizi bellekte tutmanın gerekliliğini de sorgulamak iyi bir pratik olacaktır:

filtered_data = musteri[(musteriler['yaş'] > 30) | (musteriler['şehir'] == 'İstanbul')]

# Belleği yönetin, gereksiz objeleri silin
import gc
gc.collect()

Yukarıdaki örnekte, filtreleme işlemi sonrasında gereksiz nesnelerin bellek kullanımını azaltmak için çöp toplayıcı (garbage collector) kullanılmaktadır. Bu tür teknikler, büyük veri setlerinde performansı artırmak için tercih edilebilir.

Sonuç: ‘or’ Operatörünün Gücünü Kullanın

Pandas kütüphanesinde ‘or’ operatörü, veri analizi ve filtreleme işlemlerinde son derece güçlü bir araçtır. Kullanım kolaylığı ile birleştirildiğinde, karmaşık veri setleri üzerinde çalışmayı ve belirli koşullara göre verileri filtrelemeyi oldukça basit hale getirir. Koşul ifadelerinin parantezleri ile doğru bir yapıda kullanılması, hataların önüne geçerken, veri analizi sürecinin etkinliğini artırır.

Veri analizi sırasında koşullarınızı dikkatlice tanımlamak, hedef kitleleri bulmak ve iş kararlarınızı desteklemek için size büyük bir avantaj sağlayacaktır. Kendinizi bu mantıksal operatörlerin çeşitli kombinasyonlarıyla denemekten çekinmeyin. Pandas ile birlikte kullanıldığında, ‘or’ operatörünün sunduğu esneklik, karmaşık veri analizlerinin üstesinden gelmenente yardımcı olacaktır. Her zaman olduğu gibi, denemeler yapmaya ve yeni çözümler keşfetmeye devam edin!

Kaynaklar ve Ekstra Bilgi

İleri düzey veri analizleri için Pandas belgeleri, çevrimiçi kurslar ve topluluk forumları faydalı kaynaklar olabilir. Bu kaynaklar üzerinden daha fazla bilgi edinmek ve yeni teknikler öğrenmek için zaman ayırmayı unutmayın. Herhangi bir sorunuz veya paylaşmak istediğiniz deneyiminiz varsa, yorum bölümünde beğenisel görüşlerinizi bekliyoruz!

Scroll to Top