<?xml version="1.0" encoding="UTF-8" standalone="no"?><rss xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd" xmlns:slash="http://purl.org/rss/1.0/modules/slash/" xmlns:sy="http://purl.org/rss/1.0/modules/syndication/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" version="2.0">

<channel>
	<title>SDC</title>
	<atom:link href="http://www.kursatsenturk.com/feed" rel="self" type="application/rss+xml"/>
	<link>https://www.kursatsenturk.com</link>
	<description>Kodlarla Dünyayı Değiştiriyoruz  Kürşat Şentürk www.kursatsenturk.com</description>
	<lastBuildDate>Thu, 30 Apr 2026 10:18:53 +0000</lastBuildDate>
	<language>tr</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=7.0</generator>
	<itunes:explicit>no</itunes:explicit><itunes:summary>Kodlarla Dünyayı Değiştiriyoruz Kürşat Şentürk www.kursatsenturk.com</itunes:summary><itunes:subtitle>Kodlarla Dünyayı Değiştiriyoruz Kürşat Şentürk www.kursatsenturk.com</itunes:subtitle><item>
		<title>BorsaPin Frama Strateji Algoritması (TradingView)</title>
		<link>https://www.kursatsenturk.com/2026/04/borsapin-frama-strateji-algoritmasi-tradingview.html</link>
					<comments>https://www.kursatsenturk.com/2026/04/borsapin-frama-strateji-algoritmasi-tradingview.html#respond</comments>
		
		<dc:creator><![CDATA[sdc]]></dc:creator>
		<pubDate>Thu, 30 Apr 2026 09:45:32 +0000</pubDate>
				<category><![CDATA[İndikatör]]></category>
		<category><![CDATA[Pine Script]]></category>
		<category><![CDATA[Teknik Analiz]]></category>
		<category><![CDATA[Trading View]]></category>
		<category><![CDATA[algoritmik trading]]></category>
		<category><![CDATA[borsa strateji geliştirme]]></category>
		<category><![CDATA[Borsa trading stratejileri]]></category>
		<category><![CDATA[BorsaPin stratejisi]]></category>
		<category><![CDATA[FRAMA nedir]]></category>
		<category><![CDATA[FRAMA stratejisi]]></category>
		<category><![CDATA[hisse senedi alım satım stratejisi]]></category>
		<category><![CDATA[momentum stratejisi]]></category>
		<category><![CDATA[otomatik trading sistemi]]></category>
		<category><![CDATA[Pine Script strateji]]></category>
		<category><![CDATA[Supertrend nasıl kullanılır]]></category>
		<category><![CDATA[Supertrend stratejisi]]></category>
		<category><![CDATA[teknik analiz göstergeleri]]></category>
		<category><![CDATA[TradingView strateji kodu]]></category>
		<category><![CDATA[trend takip stratejisi]]></category>
		<guid isPermaLink="false">https://www.kursatsenturk.com/?p=11553</guid>

					<description><![CDATA[<p>Herkese Merhaba, Uzun zamandır blog yazısı paylaşmıyordum, trading view için geliştirdiğim strateji koduyla dönelim dedik. Şimdi borsapin frama stratejisi, trend takibini daha “akıllı” hale getirmek için iki güçlü yaklaşım kullanıyor.  FRAMA (Fractal Adaptive Moving Average) ve Supertrend. Amaç, piyasadaki gürültüyü filtreleyip yalnızca güçlü ve sürdürülebilir trendlere girmek. Stratejinin temelinde üç katmanlı bir filtreleme var. İlk [&#8230;]</p>
<p>The post <a href="https://www.kursatsenturk.com/2026/04/borsapin-frama-strateji-algoritmasi-tradingview.html">BorsaPin Frama Strateji Algoritması (TradingView)</a> first appeared on <a href="https://www.kursatsenturk.com">SDC</a>.</p>]]></description>
										<content:encoded><![CDATA[<p><a href="https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw.png"><img fetchpriority="high" decoding="async" class="aligncenter size-full wp-image-11505" src="https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw.png" alt="" width="777" height="548" srcset="https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw.png 777w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw-300x212.png 300w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw-768x542.png 768w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw-679x479.png 679w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw-262x185.png 262w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw-574x405.png 574w" sizes="(max-width: 777px) 100vw, 777px" /></a></p>
<p>Herkese Merhaba, Uzun zamandır blog yazısı paylaşmıyordum, trading view için geliştirdiğim strateji koduyla dönelim dedik. <br />Şimdi borsapin frama stratejisi, trend takibini daha “akıllı” hale getirmek için iki güçlü yaklaşım kullanıyor.  FRAMA (Fractal Adaptive Moving Average) ve Supertrend. Amaç, piyasadaki gürültüyü filtreleyip yalnızca güçlü ve sürdürülebilir trendlere girmek. <br /><br />Stratejinin temelinde üç katmanlı bir filtreleme var. İlk olarak haftalık zaman diliminde FRAMA’nın yukarı eğimli olması gerekiyor. Bu, büyük resimde piyasanın gerçekten yükseliş trendinde olduğunu doğrular ve yatay piyasaları büyük ölçüde eler. Ardından günlük grafikte fiyatın FRAMA’nın üzerinde olması ve aynı zamanda FRAMA’nın yukarı yönlü olması gerekiyor. Son olarak ise Supertrend göstergesinin alış sinyali üretmesiyle bu üç koşul birlikte sağlandığında sistem “onaylı” bir long pozisyon açıyor. <br />Çıkış tarafında ise aceleci davranılmıyor. Günlük FRAMA’nın altına iniş tek başına yeterli değil; belirli sayıda bar boyunca bu zayıflığın devam etmesi gerekiyor. Buna ek olarak Supertrend’in satış sinyali vermesiyle birlikte pozisyon kapatılıyor. <br /><br />Buradaki yaklaşım, ani dalgalanmalarda gereksiz çıkışları azaltmak,  kısa vadeli gürültüyü filtreleyip orta-uzun vadeli trendleri yakalamaya odaklanıyoruz, disiplinli bir trend takip sistemi size sunar.. Özellikle “trend varsa kal, yoksa uzak dur” yada &#8220;düşen bıçağı tutma&#8221; mantıklarından esinlenildi. <br /><br /></p>

<div class="wp-block-kevinbatdorf-code-block-pro" style="font-size: .875rem; font-family: Code-Pro-JetBrains-Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace; line-height: 1.25rem; --cbp-tab-width: 2; tab-size: var(--cbp-tab-width, 2);" data-code-block-pro-font-family="Code-Pro-JetBrains-Mono">
<pre class="code-block-pro-copy-button-pre" aria-hidden="true"><textarea class="code-block-pro-copy-button-textarea" tabindex="-1" readonly="readonly" aria-hidden="true">// @frama &amp; Supertrend - BorsaPin Kursatsenturk.com
// Giriş: Haftalık Yukarı Eğimli olacak + Günlük FRAMA  AL sinyali verecek + Supertrend AL
// Çıkış: Günlük FRAMA (Teyitli) + Supertrend SAT

//@version=5
strategy("@frama BorsaPin Stratejisi", overlay=true, initial_capital=10000, 
     default_qty_type=strategy.percent_of_equity, default_qty_value=100,
     process_orders_on_close=true)

// ═══════════════════════════════════════════════════════════════
// GİRDİLER
// ═══════════════════════════════════════════════════════════════
grp_date = "Backtest Tarih Aralığı"
startDate = input.time(timestamp("2024-01-01 00:00 +0300"), "Başlangıç", group=grp_date)
endDate   = input.time(timestamp("2026-12-31 23:59 +0300"), "Bitiş", group=grp_date)
isInDate_Range = time &gt;= startDate and time &lt;= endDate

grp_params = "Gösterge Ayarları"
frama_len    = input.int(16,  "FRAMA Uzunluk", group=grp_params)
fc           = input.int(1,   "Hızlı Periyot (FC)", group=grp_params)
sc           = input.int(200, "Yavaş Periyot (SC)", group=grp_params)
st_len       = input.int(10,  "Supertrend Periyot", group=grp_params)
st_mult      = input.float(3.4, "Supertrend Çarpan", step=0.1, group=grp_params)

grp_logic = "Giriş ve Çıkış Filtreleri"
slope_thresh = input.float(0.1, "Haftalık Min. Eğim % (Yatay Filtresi)", step=0.01, group=grp_logic)
confirm_bars = input.int(3, "Satış Öncesi Bekleme (Bar Sayısı)", minval=1, group=grp_logic)

// ═══════════════════════════════════════════════════════════════
// Frama Hesaplama Fonksiyonu
// ═══════════════════════════════════════════════════════════════
f_frama(_src, _len, _fc, _sc) =&gt;
    float _frama = na
    _half = _len / 2
    _n1 = (ta.highest(high, _half) - ta.lowest(low, _half)) / _half
    _n2 = (ta.highest(high[_half], _half) - ta.lowest(low[_half], _half)) / _half
    _n3 = (ta.highest(high, _len) - ta.lowest(low, _len)) / _len
    _dimen = (_n1 &gt; 0 and _n2 &gt; 0 and _n3 &gt; 0) ? (math.log(_n1 + _n2) - math.log(_n3)) / math.log(2) : 1.0
    _w = math.exp(-4.6 * (_dimen - 1))
    _sc_a = 2.0 / (_sc + 1), _fc_a = 2.0 / (_fc + 1)
    _alpha = math.max(_sc_a, math.min(_fc_a, _w * (_fc_a - _sc_a) + _sc_a))
    _frama := na(_frama[1]) ? _src : (_alpha * _src) + ((1.0 - _alpha) * nz(_frama[1], _src))
    [_frama, _frama &gt; nz(_frama[1], 0)]

// ═══════════════════════════════════════════════════════════════
// Hesaplamalar
// ═══════════════════════════════════════════════════════════════
// 1. Haftalık Frama (10 İşlem Günü / 2 Hafta Modu)
[wf_val, wf_up] = request.security(syminfo.tickerid, "W", f_frama(hlc3, frama_len, fc, sc), lookahead=barmerge.lookahead_on)
wf_slope_pct = ((wf_val - nz(wf_val[1])) / nz(wf_val[1])) * 100
wf_strict_up = wf_up and wf_slope_pct &gt; slope_thresh // Yatay piyasa filtresi

// 2. Günlük Frama
[f_val, f_up] = f_frama(hlc3, frama_len, fc, sc)

// 3. Günlük Supertrend
[st_val, st_dir] = ta.supertrend(st_mult, st_len)
st_buy = st_dir == -1

// ═══════════════════════════════════════════════════════════════
// Mantık
// ═══════════════════════════════════════════════════════════════
// Giriş: Haftalık Eğim + Günlük Frama Üstü + Supertrend Yeşil
long_entry = wf_strict_up and close &gt; f_val and st_buy

// ÇIKIŞ: Günlük Frama Altı (onaylı) + Supertrend Kırmızı
var int bars_below_frama = 0
bars_below_frama := (close &lt; f_val or not f_up) ? bars_below_frama + 1 : 0
long_exit = (bars_below_frama &gt;= confirm_bars) and (st_dir == 1)

// ═══════════════════════════════════════════════════════════════
// Görseller
// ═══════════════════════════════════════════════════════════════
// Haftalık (Mavi), Günlük (Yeşil/Kırmızı), Supertrend  
plot(wf_val, "Haftalık Kilit", color=wf_strict_up ? color.blue : color.gray, linewidth=4)
plot(f_val, "Günlük Frama", color=f_up ? color.green : color.red, linewidth=2)
plot(st_val, "Supertrend", color=st_buy ? color.teal : color.orange, style=plot.style_linebr)

// Mum Boyama
bar_color = long_entry ? #00ff88 : (strategy.position_size &gt; 0 and not long_exit ? #9ea4ad : #ff0044)
barcolor(bar_color)

// ═══════════════════════════════════════════════════════════════
// Emirler
// ═══════════════════════════════════════════════════════════════
if isInDate_Range
    if long_entry
        strategy.entry("Long", strategy.long, comment="Onaylı AL")
    
    if long_exit and strategy.position_size &gt; 0
        strategy.close("Long", comment="Onaylı Çıkış")

</textarea></pre>
<pre class="shiki nord" style="background-color: #2e3440ff;" tabindex="0"><code><span class="line"><span style="color: #616e88;">// @frama &amp; Supertrend - BorsaPin Kursatsenturk.com</span></span>
<span class="line"><span style="color: #616e88;">// Giriş: Haftalık Yukarı Eğimli olacak + Günlük FRAMA  AL sinyali verecek + Supertrend AL</span></span>
<span class="line"><span style="color: #616e88;">// Çıkış: Günlük FRAMA (Teyitli) + Supertrend SAT</span></span>

<span class="line"><span style="color: #616e88;">//@version=5</span></span>
<span class="line"><span style="color: #88c0d0;">strategy</span><span style="color: #d8dee9ff;">(</span><span style="color: #eceff4;">"</span><span style="color: #a3be8c;">@frama BorsaPin Stratejisi</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">overlay</span><span style="color: #81a1c1;">=true</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">initial_capital</span><span style="color: #81a1c1;">=</span><span style="color: #b48ead;">10000</span><span style="color: #eceff4;">,</span> </span>
<span class="line">     <span style="color: #d8dee9;">default_qty_type</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">strategy</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">percent_of_equity</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">default_qty_value</span><span style="color: #81a1c1;">=</span><span style="color: #b48ead;">100</span><span style="color: #eceff4;">,</span></span>
<span class="line">     <span style="color: #d8dee9;">process_orders_on_close</span><span style="color: #81a1c1;">=true</span><span style="color: #d8dee9ff;">)</span></span>

<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #616e88;">// GİRDİLER</span></span>
<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #d8dee9;">grp_date</span> <span style="color: #81a1c1;">=</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Backtest Tarih Aralığı</span><span style="color: #eceff4;">"</span></span>
<span class="line"><span style="color: #d8dee9;">startDate</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">input</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">time</span><span style="color: #d8dee9ff;">(</span><span style="color: #88c0d0;">timestamp</span><span style="color: #d8dee9ff;">(</span><span style="color: #eceff4;">"</span><span style="color: #a3be8c;">2024-01-01 00:00 +0300</span><span style="color: #eceff4;">"</span><span style="color: #d8dee9ff;">)</span><span style="color: #eceff4;">,</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Başlangıç</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">group</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">grp_date</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #d8dee9;">endDate</span>   <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">input</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">time</span><span style="color: #d8dee9ff;">(</span><span style="color: #88c0d0;">timestamp</span><span style="color: #d8dee9ff;">(</span><span style="color: #eceff4;">"</span><span style="color: #a3be8c;">2026-12-31 23:59 +0300</span><span style="color: #eceff4;">"</span><span style="color: #d8dee9ff;">)</span><span style="color: #eceff4;">,</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Bitiş</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">group</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">grp_date</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #d8dee9;">isInDate_Range</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">time</span> <span style="color: #81a1c1;">&gt;=</span> <span style="color: #d8dee9;">startDate</span> <span style="color: #d8dee9;">and</span> <span style="color: #d8dee9;">time</span> <span style="color: #81a1c1;">&lt;=</span> <span style="color: #d8dee9;">endDate</span></span>

<span class="line"><span style="color: #d8dee9;">grp_params</span> <span style="color: #81a1c1;">=</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Gösterge Ayarları</span><span style="color: #eceff4;">"</span></span>
<span class="line"><span style="color: #d8dee9;">frama_len</span>    <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">input</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">int</span><span style="color: #d8dee9ff;">(</span><span style="color: #b48ead;">16</span><span style="color: #eceff4;">,</span>  <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">FRAMA Uzunluk</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">group</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">grp_params</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #d8dee9;">fc</span>           <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">input</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">int</span><span style="color: #d8dee9ff;">(</span><span style="color: #b48ead;">1</span><span style="color: #eceff4;">,</span>   <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Hızlı Periyot (FC)</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">group</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">grp_params</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #d8dee9;">sc</span>           <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">input</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">int</span><span style="color: #d8dee9ff;">(</span><span style="color: #b48ead;">200</span><span style="color: #eceff4;">,</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Yavaş Periyot (SC)</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">group</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">grp_params</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #d8dee9;">st_len</span>       <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">input</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">int</span><span style="color: #d8dee9ff;">(</span><span style="color: #b48ead;">10</span><span style="color: #eceff4;">,</span>  <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Supertrend Periyot</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">group</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">grp_params</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #d8dee9;">st_mult</span>      <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">input</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">float</span><span style="color: #d8dee9ff;">(</span><span style="color: #b48ead;">3.4</span><span style="color: #eceff4;">,</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Supertrend Çarpan</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">step</span><span style="color: #81a1c1;">=</span><span style="color: #b48ead;">0.1</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">group</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">grp_params</span><span style="color: #d8dee9ff;">)</span></span>

<span class="line"><span style="color: #d8dee9;">grp_logic</span> <span style="color: #81a1c1;">=</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Giriş ve Çıkış Filtreleri</span><span style="color: #eceff4;">"</span></span>
<span class="line"><span style="color: #d8dee9;">slope_thresh</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">input</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">float</span><span style="color: #d8dee9ff;">(</span><span style="color: #b48ead;">0.1</span><span style="color: #eceff4;">,</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Haftalık Min. Eğim % (Yatay Filtresi)</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">step</span><span style="color: #81a1c1;">=</span><span style="color: #b48ead;">0.01</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">group</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">grp_logic</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #d8dee9;">confirm_bars</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">input</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">int</span><span style="color: #d8dee9ff;">(</span><span style="color: #b48ead;">3</span><span style="color: #eceff4;">,</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Satış Öncesi Bekleme (Bar Sayısı)</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">minval</span><span style="color: #81a1c1;">=</span><span style="color: #b48ead;">1</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">group</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">grp_logic</span><span style="color: #d8dee9ff;">)</span></span>

<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #616e88;">// Frama Hesaplama Fonksiyonu</span></span>
<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #88c0d0;">f_frama</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">_src</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_len</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_fc</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_sc</span><span style="color: #d8dee9ff;">) </span><span style="color: #81a1c1;">=&gt;</span></span>
<span class="line">    <span style="color: #d8dee9;">float</span> <span style="color: #d8dee9;">_frama</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">na</span></span>
<span class="line">    <span style="color: #d8dee9;">_half</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">_len</span> <span style="color: #81a1c1;">/</span> <span style="color: #b48ead;">2</span></span>
<span class="line">    <span style="color: #d8dee9;">_n1</span> <span style="color: #81a1c1;">=</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">ta</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">highest</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">high</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_half</span><span style="color: #d8dee9ff;">) </span><span style="color: #81a1c1;">-</span> <span style="color: #d8dee9;">ta</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">lowest</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">low</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_half</span><span style="color: #d8dee9ff;">)) </span><span style="color: #81a1c1;">/</span> <span style="color: #d8dee9;">_half</span></span>
<span class="line">    <span style="color: #d8dee9;">_n2</span> <span style="color: #81a1c1;">=</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">ta</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">highest</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">high</span><span style="color: #d8dee9ff;">[</span><span style="color: #d8dee9;">_half</span><span style="color: #d8dee9ff;">]</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_half</span><span style="color: #d8dee9ff;">) </span><span style="color: #81a1c1;">-</span> <span style="color: #d8dee9;">ta</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">lowest</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">low</span><span style="color: #d8dee9ff;">[</span><span style="color: #d8dee9;">_half</span><span style="color: #d8dee9ff;">]</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_half</span><span style="color: #d8dee9ff;">)) </span><span style="color: #81a1c1;">/</span> <span style="color: #d8dee9;">_half</span></span>
<span class="line">    <span style="color: #d8dee9;">_n3</span> <span style="color: #81a1c1;">=</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">ta</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">highest</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">high</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_len</span><span style="color: #d8dee9ff;">) </span><span style="color: #81a1c1;">-</span> <span style="color: #d8dee9;">ta</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">lowest</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">low</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_len</span><span style="color: #d8dee9ff;">)) </span><span style="color: #81a1c1;">/</span> <span style="color: #d8dee9;">_len</span></span>
<span class="line">    <span style="color: #d8dee9;">_dimen</span> <span style="color: #81a1c1;">=</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">_n1</span> <span style="color: #81a1c1;">&gt;</span> <span style="color: #b48ead;">0</span> <span style="color: #d8dee9;">and</span> <span style="color: #d8dee9;">_n2</span> <span style="color: #81a1c1;">&gt;</span> <span style="color: #b48ead;">0</span> <span style="color: #d8dee9;">and</span> <span style="color: #d8dee9;">_n3</span> <span style="color: #81a1c1;">&gt;</span> <span style="color: #b48ead;">0</span><span style="color: #d8dee9ff;">) </span><span style="color: #81a1c1;">?</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">math</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">log</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">_n1</span> <span style="color: #81a1c1;">+</span> <span style="color: #d8dee9;">_n2</span><span style="color: #d8dee9ff;">) </span><span style="color: #81a1c1;">-</span> <span style="color: #d8dee9;">math</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">log</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">_n3</span><span style="color: #d8dee9ff;">)) </span><span style="color: #81a1c1;">/</span> <span style="color: #d8dee9;">math</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">log</span><span style="color: #d8dee9ff;">(</span><span style="color: #b48ead;">2</span><span style="color: #d8dee9ff;">) </span><span style="color: #81a1c1;">:</span> <span style="color: #b48ead;">1.0</span></span>
<span class="line">    <span style="color: #d8dee9;">_w</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">math</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">exp</span><span style="color: #d8dee9ff;">(</span><span style="color: #81a1c1;">-</span><span style="color: #b48ead;">4.6</span> <span style="color: #81a1c1;">*</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">_dimen</span> <span style="color: #81a1c1;">-</span> <span style="color: #b48ead;">1</span><span style="color: #d8dee9ff;">))</span></span>
<span class="line">    <span style="color: #d8dee9;">_sc_a</span> <span style="color: #81a1c1;">=</span> <span style="color: #b48ead;">2.0</span> <span style="color: #81a1c1;">/</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">_sc</span> <span style="color: #81a1c1;">+</span> <span style="color: #b48ead;">1</span><span style="color: #d8dee9ff;">)</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_fc_a</span> <span style="color: #81a1c1;">=</span> <span style="color: #b48ead;">2.0</span> <span style="color: #81a1c1;">/</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">_fc</span> <span style="color: #81a1c1;">+</span> <span style="color: #b48ead;">1</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line">    <span style="color: #d8dee9;">_alpha</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">math</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">max</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">_sc_a</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">math</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">min</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">_fc_a</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_w</span> <span style="color: #81a1c1;">*</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">_fc_a</span> <span style="color: #81a1c1;">-</span> <span style="color: #d8dee9;">_sc_a</span><span style="color: #d8dee9ff;">) </span><span style="color: #81a1c1;">+</span> <span style="color: #d8dee9;">_sc_a</span><span style="color: #d8dee9ff;">))</span></span>
<span class="line"><span style="color: #d8dee9ff;">    _frama </span><span style="color: #eceff4;">:</span><span style="color: #81a1c1;">=</span> <span style="color: #88c0d0;">na</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">_frama</span><span style="color: #d8dee9ff;">[</span><span style="color: #b48ead;">1</span><span style="color: #d8dee9ff;">]) </span><span style="color: #81a1c1;">?</span> <span style="color: #d8dee9;">_src</span> <span style="color: #81a1c1;">:</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">_alpha</span> <span style="color: #81a1c1;">*</span> <span style="color: #d8dee9;">_src</span><span style="color: #d8dee9ff;">) </span><span style="color: #81a1c1;">+</span><span style="color: #d8dee9ff;"> ((</span><span style="color: #b48ead;">1.0</span> <span style="color: #81a1c1;">-</span> <span style="color: #d8dee9;">_alpha</span><span style="color: #d8dee9ff;">) </span><span style="color: #81a1c1;">*</span> <span style="color: #88c0d0;">nz</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">_frama</span><span style="color: #d8dee9ff;">[</span><span style="color: #b48ead;">1</span><span style="color: #d8dee9ff;">]</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_src</span><span style="color: #d8dee9ff;">))</span></span>
<span class="line"><span style="color: #d8dee9ff;">    [</span><span style="color: #d8dee9;">_frama</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">_frama</span> <span style="color: #81a1c1;">&gt;</span> <span style="color: #88c0d0;">nz</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">_frama</span><span style="color: #d8dee9ff;">[</span><span style="color: #b48ead;">1</span><span style="color: #d8dee9ff;">]</span><span style="color: #eceff4;">,</span> <span style="color: #b48ead;">0</span><span style="color: #d8dee9ff;">)]</span></span>

<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #616e88;">// Hesaplamalar</span></span>
<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #616e88;">// 1. Haftalık Frama (10 İşlem Günü / 2 Hafta Modu)</span></span>
<span class="line"><span style="color: #d8dee9ff;">[</span><span style="color: #d8dee9;">wf_val</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">wf_up</span><span style="color: #d8dee9ff;">] </span><span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">request</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">security</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">syminfo</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">tickerid</span><span style="color: #eceff4;">,</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">W</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #88c0d0;">f_frama</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">hlc3</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">frama_len</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">fc</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">sc</span><span style="color: #d8dee9ff;">)</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">lookahead</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">barmerge</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">lookahead_on</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #d8dee9;">wf_slope_pct</span> <span style="color: #81a1c1;">=</span><span style="color: #d8dee9ff;"> ((</span><span style="color: #d8dee9;">wf_val</span> <span style="color: #81a1c1;">-</span> <span style="color: #88c0d0;">nz</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">wf_val</span><span style="color: #d8dee9ff;">[</span><span style="color: #b48ead;">1</span><span style="color: #d8dee9ff;">])) </span><span style="color: #81a1c1;">/</span> <span style="color: #88c0d0;">nz</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">wf_val</span><span style="color: #d8dee9ff;">[</span><span style="color: #b48ead;">1</span><span style="color: #d8dee9ff;">])) </span><span style="color: #81a1c1;">*</span> <span style="color: #b48ead;">100</span></span>
<span class="line"><span style="color: #d8dee9;">wf_strict_up</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">wf_up</span> <span style="color: #d8dee9;">and</span> <span style="color: #d8dee9;">wf_slope_pct</span> <span style="color: #81a1c1;">&gt;</span> <span style="color: #d8dee9;">slope_thresh</span> <span style="color: #616e88;">// Yatay piyasa filtresi</span></span>

<span class="line"><span style="color: #616e88;">// 2. Günlük Frama</span></span>
<span class="line"><span style="color: #d8dee9ff;">[</span><span style="color: #d8dee9;">f_val</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">f_up</span><span style="color: #d8dee9ff;">] </span><span style="color: #81a1c1;">=</span> <span style="color: #88c0d0;">f_frama</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">hlc3</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">frama_len</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">fc</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">sc</span><span style="color: #d8dee9ff;">)</span></span>

<span class="line"><span style="color: #616e88;">// 3. Günlük Supertrend</span></span>
<span class="line"><span style="color: #d8dee9ff;">[</span><span style="color: #d8dee9;">st_val</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">st_dir</span><span style="color: #d8dee9ff;">] </span><span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">ta</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">supertrend</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">st_mult</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">st_len</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #d8dee9;">st_buy</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">st_dir</span> <span style="color: #81a1c1;">==</span> <span style="color: #81a1c1;">-</span><span style="color: #b48ead;">1</span></span>

<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #616e88;">// Mantık</span></span>
<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #616e88;">// Giriş: Haftalık Eğim + Günlük Frama Üstü + Supertrend Yeşil</span></span>
<span class="line"><span style="color: #d8dee9;">long_entry</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">wf_strict_up</span> <span style="color: #d8dee9;">and</span> <span style="color: #d8dee9;">close</span> <span style="color: #81a1c1;">&gt;</span> <span style="color: #d8dee9;">f_val</span> <span style="color: #d8dee9;">and</span> <span style="color: #d8dee9;">st_buy</span></span>

<span class="line"><span style="color: #616e88;">// ÇIKIŞ: Günlük Frama Altı (onaylı) + Supertrend Kırmızı</span></span>
<span class="line"><span style="color: #81a1c1;">var</span> <span style="color: #d8dee9;">int</span><span style="color: #d8dee9ff;"> bars_below_frama </span><span style="color: #81a1c1;">=</span> <span style="color: #b48ead;">0</span></span>
<span class="line"><span style="color: #d8dee9ff;">bars_below_frama </span><span style="color: #eceff4;">:</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">close</span> <span style="color: #81a1c1;">&lt;</span> <span style="color: #d8dee9;">f_val</span> <span style="color: #d8dee9;">or</span> <span style="color: #d8dee9;">not</span> <span style="color: #d8dee9;">f_up</span><span style="color: #d8dee9ff;">) </span><span style="color: #81a1c1;">?</span> <span style="color: #d8dee9;">bars_below_frama</span> <span style="color: #81a1c1;">+</span> <span style="color: #b48ead;">1</span> <span style="color: #81a1c1;">:</span> <span style="color: #b48ead;">0</span></span>
<span class="line"><span style="color: #d8dee9;">long_exit</span> <span style="color: #81a1c1;">=</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">bars_below_frama</span> <span style="color: #81a1c1;">&gt;=</span> <span style="color: #d8dee9;">confirm_bars</span><span style="color: #d8dee9ff;">) </span><span style="color: #88c0d0;">and</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">st_dir</span> <span style="color: #81a1c1;">==</span> <span style="color: #b48ead;">1</span><span style="color: #d8dee9ff;">)</span></span>

<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #616e88;">// Görseller</span></span>
<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #616e88;">// Haftalık (Mavi), Günlük (Yeşil/Kırmızı), Supertrend  </span></span>
<span class="line"><span style="color: #88c0d0;">plot</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">wf_val</span><span style="color: #eceff4;">,</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Haftalık Kilit</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">color</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">wf_strict_up</span> <span style="color: #81a1c1;">?</span> <span style="color: #d8dee9;">color</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">blue</span> <span style="color: #81a1c1;">:</span> <span style="color: #d8dee9;">color</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">gray</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">linewidth</span><span style="color: #81a1c1;">=</span><span style="color: #b48ead;">4</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #88c0d0;">plot</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">f_val</span><span style="color: #eceff4;">,</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Günlük Frama</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">color</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">f_up</span> <span style="color: #81a1c1;">?</span> <span style="color: #d8dee9;">color</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">green</span> <span style="color: #81a1c1;">:</span> <span style="color: #d8dee9;">color</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">red</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">linewidth</span><span style="color: #81a1c1;">=</span><span style="color: #b48ead;">2</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #88c0d0;">plot</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">st_val</span><span style="color: #eceff4;">,</span> <span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Supertrend</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">color</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">st_buy</span> <span style="color: #81a1c1;">?</span> <span style="color: #d8dee9;">color</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">teal</span> <span style="color: #81a1c1;">:</span> <span style="color: #d8dee9;">color</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">orange</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">style</span><span style="color: #81a1c1;">=</span><span style="color: #d8dee9;">plot</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">style_linebr</span><span style="color: #d8dee9ff;">)</span></span>

<span class="line"><span style="color: #616e88;">// Mum Boyama</span></span>
<span class="line"><span style="color: #d8dee9;">bar_color</span> <span style="color: #81a1c1;">=</span> <span style="color: #d8dee9;">long_entry</span> <span style="color: #81a1c1;">?</span><span style="color: #d8dee9ff;"> #00</span><span style="color: #d8dee9;">ff88</span> <span style="color: #81a1c1;">:</span><span style="color: #d8dee9ff;"> (</span><span style="color: #d8dee9;">strategy</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">position_size</span> <span style="color: #81a1c1;">&gt;</span> <span style="color: #b48ead;">0</span> <span style="color: #d8dee9;">and</span> <span style="color: #d8dee9;">not</span> <span style="color: #d8dee9;">long_exit</span> <span style="color: #81a1c1;">?</span><span style="color: #d8dee9ff;"> #9</span><span style="color: #d8dee9;">ea4ad</span> <span style="color: #81a1c1;">:</span><span style="color: #d8dee9ff;"> #</span><span style="color: #d8dee9;">ff0044</span><span style="color: #d8dee9ff;">)</span></span>
<span class="line"><span style="color: #88c0d0;">barcolor</span><span style="color: #d8dee9ff;">(</span><span style="color: #d8dee9;">bar_color</span><span style="color: #d8dee9ff;">)</span></span>

<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #616e88;">// Emirler</span></span>
<span class="line"><span style="color: #616e88;">// ═══════════════════════════════════════════════════════════════</span></span>
<span class="line"><span style="color: #81a1c1;">if</span> <span style="color: #d8dee9;">isInDate_Range</span></span>
<span class="line">    <span style="color: #81a1c1;">if</span> <span style="color: #d8dee9;">long_entry</span></span>
<span class="line">        <span style="color: #d8dee9;">strategy</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">entry</span><span style="color: #d8dee9ff;">(</span><span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Long</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">strategy</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">long</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">comment</span><span style="color: #81a1c1;">=</span><span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Onaylı AL</span><span style="color: #eceff4;">"</span><span style="color: #d8dee9ff;">)</span></span>
    
<span class="line">    <span style="color: #81a1c1;">if</span> <span style="color: #d8dee9;">long_exit</span> <span style="color: #d8dee9;">and</span> <span style="color: #d8dee9;">strategy</span><span style="color: #eceff4;">.</span><span style="color: #d8dee9;">position_size</span> <span style="color: #81a1c1;">&gt;</span> <span style="color: #b48ead;">0</span></span>
<span class="line">        <span style="color: #d8dee9;">strategy</span><span style="color: #eceff4;">.</span><span style="color: #88c0d0;">close</span><span style="color: #d8dee9ff;">(</span><span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Long</span><span style="color: #eceff4;">"</span><span style="color: #eceff4;">,</span> <span style="color: #d8dee9;">comment</span><span style="color: #81a1c1;">=</span><span style="color: #eceff4;">"</span><span style="color: #a3be8c;">Onaylı Çıkış</span><span style="color: #eceff4;">"</span><span style="color: #d8dee9ff;">)</span></span>

</code></pre>
</div>



<p class="wp-block-paragraph">&nbsp;</p>

<blockquote>
<p><strong>Bu strateji güçlü bir trend takip sistemi olsa da, bazı önemli sakıncaları ve dikkat edilmesi gereken noktalar var.</strong> <br />Öncelikle FRAMA ve Supertrend gibi trend bazlı göstergeler, yatay (sideways) piyasalarda gecikmeli ve yanıltıcı sinyaller üretir. Özellikle trend oluşmadan önce yapılan girişler küçük geri çekilmelerde stop olma riskini artırır. <br />Haftalık filtre bu riski azaltmaya çalışsa da tamamen ortadan kaldırmayabilir. İkinci olarak, strateji gecikmeli (lagging) bir yapıya sahip. Yani fiyat hareketini önceden tahmin etmekten çok, oluşmuş trendi takip eder. Bu durum güçlü trendlerde avantaj sağlarken, hızlı dönüşlerde geç kalmaya neden olabilir. <br /><br /><em>Ayrıca Supertrend ve FRAMA birlikte kullanıldığı için bazı dönemlerde fazla filtreleme (over-filtering) oluşabilir ve bu da işlem sayısını ciddi şekilde azaltır. Bu, performansı artırabilir ama fırsat kaçırma riskini de beraberinde getirir. Son olarak, bu tür sistemler geçmiş veride iyi sonuç verse bile, piyasa rejimi değiştiğinde (volatilite, haber akışı, kriz dönemleri) performansları farklılaşır. Bu nedenle bu stratejiyi  tek başına karar sistemi olarak değil, mutlaka risk yönetimi ve portföy çeşitlendirmesi ile birlikte kullanılmalı. Fundamental analizler, diğer tekniklerle desteklenmeside önemlidir.</em></p>
</blockquote><p>The post <a href="https://www.kursatsenturk.com/2026/04/borsapin-frama-strateji-algoritmasi-tradingview.html">BorsaPin Frama Strateji Algoritması (TradingView)</a> first appeared on <a href="https://www.kursatsenturk.com">SDC</a>.</p>]]></content:encoded>
					
					<wfw:commentRss>https://www.kursatsenturk.com/2026/04/borsapin-frama-strateji-algoritmasi-tradingview.html/feed</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>Python ile Otomatik EMA Sinyal Analizi: Kısa, Orta ve Uzun Vadeli Alım Stratejileri</title>
		<link>https://www.kursatsenturk.com/2025/08/python-ile-otomatik-ema-sinyal-analizi-kisa-orta-ve-uzun-vadeli-alim-stratejileri.html</link>
					<comments>https://www.kursatsenturk.com/2025/08/python-ile-otomatik-ema-sinyal-analizi-kisa-orta-ve-uzun-vadeli-alim-stratejileri.html#respond</comments>
		
		<dc:creator><![CDATA[sdc]]></dc:creator>
		<pubDate>Mon, 11 Aug 2025 12:40:29 +0000</pubDate>
				<category><![CDATA[BorsaPin]]></category>
		<category><![CDATA[Python]]></category>
		<category><![CDATA[Teknik Analiz]]></category>
		<category><![CDATA[algoritmik trading]]></category>
		<category><![CDATA[alım satım sinyalleri]]></category>
		<category><![CDATA[borsa]]></category>
		<category><![CDATA[borsa otomasyonu]]></category>
		<category><![CDATA[Ema]]></category>
		<category><![CDATA[excel raporlama]]></category>
		<category><![CDATA[hisse senedi analizi]]></category>
		<category><![CDATA[kısa vade]]></category>
		<category><![CDATA[orta vade]]></category>
		<category><![CDATA[otomatik analiz]]></category>
		<category><![CDATA[pin bar]]></category>
		<category><![CDATA[Pine Script]]></category>
		<category><![CDATA[sinyal takibi]]></category>
		<category><![CDATA[trend takibi]]></category>
		<category><![CDATA[üssel hareketli ortalama]]></category>
		<category><![CDATA[uzun vade]]></category>
		<category><![CDATA[yatırım stratejisi]]></category>
		<guid isPermaLink="false">https://www.kursatsenturk.com/?p=11517</guid>

					<description><![CDATA[<p>Betik Güncellendi 16.08.25 v1.02 Bu Python kodu, hisse senedi yatırımcıları için tasarlanmış, EMA (Üssel Hareketli Ortalama) tabanlı bir sinyal analiz sistemidir. Kod, her hisse için farklı vadelere özel sinyal üretir ve bu sinyallerin nasıl oluşup sonlandığını titizlikle takip eder. Kodun kısa, orta ve uzun vadeli sinyal mantığına dair detaylar şu şekilde Kısa Vade Sinyalleri (EMA [&#8230;]</p>
<p>The post <a href="https://www.kursatsenturk.com/2025/08/python-ile-otomatik-ema-sinyal-analizi-kisa-orta-ve-uzun-vadeli-alim-stratejileri.html">Python ile Otomatik EMA Sinyal Analizi: Kısa, Orta ve Uzun Vadeli Alım Stratejileri</a> first appeared on <a href="https://www.kursatsenturk.com">SDC</a>.</p>]]></description>
										<content:encoded><![CDATA[<figure class="wp-block-image size-full"><img decoding="async" width="777" height="548" class="wp-image-11510 aligncenter" src="https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython.png" alt="" srcset="https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython.png 777w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython-300x212.png 300w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython-768x542.png 768w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython-679x479.png 679w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython-262x185.png 262w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython-574x405.png 574w" sizes="(max-width: 777px) 100vw, 777px" /></figure>



<h2><br />Betik Güncellendi 16.08.25 v1.02</h2>
<p class="wp-block-paragraph"><br /><br />Bu Python kodu, hisse senedi yatırımcıları için tasarlanmış, <strong>EMA (Üssel Hareketli Ortalama)</strong> tabanlı bir sinyal analiz sistemidir. Kod, her hisse için farklı vadelere özel sinyal üretir ve bu sinyallerin nasıl oluşup sonlandığını titizlikle takip eder.</p>



<p class="wp-block-paragraph">Kodun kısa, orta ve uzun vadeli sinyal mantığına dair detaylar şu şekilde<br /><br /><br /></p>



<h4 class="wp-block-heading"><strong>Kısa Vade Sinyalleri (EMA 5, 8, 13, 21)</strong></h4>



<ul class="wp-block-list">
<li><strong>AL (Alım) Sinyalinin Oluşumu:</strong> Kısa vadeli bir alım sinyali, kapanış fiyatının 5, 8, 13 ve 21 günlük EMA&#8217;ların üzerinde olması ve aynı zamanda bu dört EMA&#8217;nın da bir önceki güne göre yükseliş eğiliminde olmasıyla başlar. Bu koşul, güçlü bir yukarı yönlü momentumun başladığına işaret eder.</li>



<li><strong>AL Sinyalinin Devamı:</strong> Sinyal bir kez &#8220;AL&#8221; olarak belirlendikten sonra, kapanış fiyatı 21 günlük EMA&#8217;nın üzerinde kaldığı sürece sinyal devam eder ve &#8220;Sinyal Süresi&#8221; sayacı artmaya devam eder.</li>



<li><strong>SAT (Satım) Sinyalinin Oluşumu:</strong> Fiyat 21 günlük EMA&#8217;nın altına düştüğünde, &#8220;AL&#8221; sinyali sonlanır ve &#8220;SAT&#8221; sinyali oluşur. Bu durum, kısa vadeli yükseliş trendinin zayıfladığını gösterir.</li>
</ul>



<h4 class="wp-block-heading"><strong>Orta Vade Sinyalleri (EMA 34, 55)</strong></h4>



<ul class="wp-block-list">
<li><strong>AL (Alım) Sinyalinin Oluşumu:</strong> Orta vadeli alım sinyali için fiyatın hem 34 hem de 55 günlük EMA&#8217;ların üzerinde olması ve 34 günlük EMA&#8217;nın 55 günlük EMA&#8217;yı yukarı keserek trendin yükselişe geçtiğini teyit etmesi gerekir.</li>



<li><strong>SAT (Satım) Sinyalinin Oluşumu:</strong> Fiyat 55 günlük EMA&#8217;nın altına düştüğü anda, &#8220;AL&#8221; sinyali sonlanır ve &#8220;SAT&#8221; sinyali oluşur.</li>
</ul>



<h4 class="wp-block-heading"><strong>Uzun Vade Sinyalleri (EMA 89, 144)</strong></h4>



<ul class="wp-block-list">
<li><strong>AL (Alım) Sinyalinin Oluşumu:</strong> Uzun vadeli alım sinyali, kapanış fiyatının hem 89 hem de 144 günlük EMA&#8217;ların üzerinde olmasıyla oluşur. Bu, hissenin uzun vadeli bir yükseliş trendinde olduğunu gösterir.</li>



<li><strong>SAT (Satım) Sinyalinin Oluşumu:</strong> Fiyat 144 günlük EMA&#8217;nın altına indiğinde, uzun vadeli trendin tehlikeye girdiğini belirten &#8220;SAT&#8221; sinyali oluşur.</li>
</ul>



<p class="wp-block-paragraph">Python Kodu, Daha önce oluşturduğumuz python StokData/Kapanis klasöründe bulunan hisselerin kapanış datalarını kullanır. Seans kapanışından sonra kodu çalıştırdığınızda Ema sinyallerini oluşturur, bu sinyallerin durumlarını analiz eder güncel durumu raporlar. Bu rapor, hisselerin son sinyalini, sinyalin kaç gündür aktif olduğunu ve bu süreçteki kar/zarar durumunu net bir şekilde gösterir. Bu sayede yatırımcılar, hangi hisselerin hangi trendde olduğunu kolayca anlayabilir ve buna göre pozisyonlarını yönetebilir.<br /><br /><a href="https://www.kursatsenturk.com/wp-content/uploads/2025/08/emasinyalexcel.png"><img decoding="async" class="aligncenter size-large wp-image-11518" src="https://www.kursatsenturk.com/wp-content/uploads/2025/08/emasinyalexcel-1030x380.png" alt="" width="570" height="210" srcset="https://www.kursatsenturk.com/wp-content/uploads/2025/08/emasinyalexcel-1030x380.png 1030w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/emasinyalexcel-300x111.png 300w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/emasinyalexcel-768x283.png 768w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/emasinyalexcel-1536x566.png 1536w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/emasinyalexcel-850x313.png 850w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/emasinyalexcel-679x250.png 679w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/emasinyalexcel-262x97.png 262w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/emasinyalexcel-574x212.png 574w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/emasinyalexcel.png 1852w" sizes="(max-width: 570px) 100vw, 570px" /></a><br />Örnek Excel Çalışması <br /><a href="https://www.kursatsenturk.com/wp-content/uploads/2025/08/BorsaPin_EMA_Analizleri.xlsx">BorsaPin_EMA_Analizleri</a></p>



<pre class="wp-block-preformatted">X_06_BorsaPin_EmaSinyals.py olarak adlandırdım. Ver.1.02 Güncellndi<br />Kısa orta ve uzun vade de al sat bekle gibi sinyalleri Excel'e dökümünü yapacaktır.<br /><br />Python Betiğimize ait kod<br /><br /></pre>

<pre class="EnlighterJSRAW" data-enlighter-language="python">import pandas as pd
import os
import warnings
from datetime import datetime
from colorama import Fore, init
import glob
from typing import List, Dict, Any, Optional
from openpyxl import load_workbook
from openpyxl.utils.dataframe import dataframe_to_rows
from openpyxl.styles import PatternFill, Font, Alignment, Border, Side
from openpyxl.formatting.rule import ColorScaleRule

"""
      Borsapin StokData/Kapanis klasöründeki hisse datalarından 
      Kısa, orta,uzun vade al sat tut gibi sinyalleri excele aktarır.
      Pine Script<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2122.png" alt="™" class="wp-smiley" style="height: 1em; max-height: 1em;" />'e EMA Sinyal Tablosu indikatörümüze göre güncellenmiş kurallar ile
      Sinyal bozulma uyarıları eklendi 
      Ver 1.02 
      www.kursatsenturk.com

      """

# Uyarıları kapat
warnings.filterwarnings('ignore')
init(autoreset=True)


class BorsaPinEMAAnalyzer:
    def __init__(self):
        self.ema_periods = {
            'kisa_vade': [5, 8, 13, 21],
            'orta_vade': [34, 55],
            'uzun_vade': [89, 144]
        }
        self.successful_files: List[str] = []
        self.failed_files: List[str] = []

    @staticmethod
    def calculate_ema(data: pd.Series, period: int) -&gt; pd.Series:
        """EMA hesaplama fonksiyonu"""
        return data.ewm(span=period, adjust=False).mean()

    @staticmethod
    def load_stock_data(file_path: str) -&gt; pd.DataFrame:
        """Hisse verilerini Excel dosyasından yükleme"""
        try:
            df = pd.read_excel(file_path)

            required_columns = ['Tarih', 'Kapanış']
            missing_columns = [col for col in required_columns if col not in df.columns]
            if missing_columns:
                raise ValueError(f"Excel dosyasında eksik sütunlar: {missing_columns}")

            df['Tarih'] = pd.to_datetime(df['Tarih'])
            df = df.sort_values('Tarih').reset_index(drop=True)
            return df

        except (FileNotFoundError, ValueError, pd.errors.ParserError) as e:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Veri yükleme hatası: {e}")
            return pd.DataFrame()

    def calculate_all_emas(self, df: pd.DataFrame) -&gt; pd.DataFrame:
        """Tüm EMA'ları hesapla"""
        close_prices = df['Kapanış']

        all_periods = self.ema_periods['kisa_vade'] + self.ema_periods['orta_vade'] + self.ema_periods['uzun_vade']

        for period in all_periods:
            if len(df) &gt;= period:
                df[f'EMA{period}'] = self.calculate_ema(close_prices, period)
            else:
                df[f'EMA{period}'] = pd.NA
        return df

    @staticmethod
    def check_signal_deterioration(df: pd.DataFrame, i: int) -&gt; Dict[str, str]:
        """Sinyal bozulma durumlarını kontrol et"""
        warnings = {
            'kisa_uyari': '',
            'orta_uyari': '',
            'uzun_uyari': ''
        }

        if i &lt; 1:  # En az 1 önceki veri gerekli
            return warnings

        kapanis = df.loc[i, 'Kapanış']

        # KISA VADE UYARILARI
        if all(pd.notna(df.loc[i, col]) for col in ['EMA5', 'EMA8', 'EMA13', 'EMA21']) and \
                all(pd.notna(df.loc[i - 1, col]) for col in ['EMA5', 'EMA8', 'EMA13', 'EMA21']):

            ema5, ema8, ema13, ema21 = df.loc[i, 'EMA5'], df.loc[i, 'EMA8'], df.loc[i, 'EMA13'], df.loc[i, 'EMA21']
            ema5_once, ema8_once, ema13_once = df.loc[i - 1, 'EMA5'], df.loc[i - 1, 'EMA8'], df.loc[i - 1, 'EMA13']

            # Önce durum kontrolü yap
            kisa_durum = df.loc[i, 'Kisa_Durum'] if 'Kisa_Durum' in df.columns else 'BEKLE'
            kisa_durum_once = df.loc[i - 1, 'Kisa_Durum'] if i &gt; 0 and 'Kisa_Durum' in df.columns else 'BEKLE'

            # AL sinyali varken 21 EMA altına sarktığında
            if kisa_durum == 'AL' and kapanis &lt; ema21:
                warnings['kisa_uyari'] = "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/26a0.png" alt="⚠" class="wp-smiley" style="height: 1em; max-height: 1em;" /> 21 EMA Altına Sarkma"
            # AL sinyali varken 5, 8, 13 EMA'da aşağı eğim başladığında (sinyal bozulmaya başladı)
            elif kisa_durum == 'AL' and (ema5 &lt; ema5_once and ema8 &lt; ema8_once and ema13 &lt; ema13_once):
                warnings['kisa_uyari'] = "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/26a0.png" alt="⚠" class="wp-smiley" style="height: 1em; max-height: 1em;" /> EMA Eğim Bozulması"

        # ORTA VADE UYARILARI
        if all(pd.notna(df.loc[i, col]) for col in ['EMA34', 'EMA55']) and i &gt; 0 and \
                all(pd.notna(df.loc[i - 1, col]) for col in ['EMA34', 'EMA55']):

            ema34 = df.loc[i, 'EMA34']
            ema55 = df.loc[i, 'EMA55']
            ema34_once = df.loc[i - 1, 'EMA34']
            ema55_once = df.loc[i - 1, 'EMA55']

            orta_durum = df.loc[i, 'Orta_Durum'] if 'Orta_Durum' in df.columns else 'BEKLE'
            orta_durum_once = df.loc[i - 1, 'Orta_Durum'] if i &gt; 0 and 'Orta_Durum' in df.columns else 'BEKLE'

            # AL sinyali varken 34 EMA altında kapatmalarda
            if orta_durum == 'AL' and kapanis &lt; ema34:
                warnings['orta_uyari'] = "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/26a0.png" alt="⚠" class="wp-smiley" style="height: 1em; max-height: 1em;" /> 34 EMA Altında Kapanış"
            # AL sinyali varken 34 ve 55 EMA'da aşağı eğim (sinyal bozulmaya başladı)
            elif orta_durum == 'AL' and (ema34 &lt; ema34_once and ema55 &lt; ema55_once):
                warnings['orta_uyari'] = "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/26a0.png" alt="⚠" class="wp-smiley" style="height: 1em; max-height: 1em;" /> EMA Eğim Bozulması"

        # UZUN VADE UYARILARI
        if all(pd.notna(df.loc[i, col]) for col in ['EMA89', 'EMA144']) and i &gt; 0 and \
                all(pd.notna(df.loc[i - 1, col]) for col in ['EMA89', 'EMA144']):

            ema89 = df.loc[i, 'EMA89']
            ema144 = df.loc[i, 'EMA144']
            ema89_once = df.loc[i - 1, 'EMA89']
            ema144_once = df.loc[i - 1, 'EMA144']

            uzun_durum = df.loc[i, 'Uzun_Durum'] if 'Uzun_Durum' in df.columns else 'BEKLE'
            uzun_durum_once = df.loc[i - 1, 'Uzun_Durum'] if i &gt; 0 and 'Uzun_Durum' in df.columns else 'BEKLE'

            # AL sinyali varken 89 EMA altına sarkmada
            if uzun_durum == 'AL' and kapanis &lt; ema89:
                warnings['uzun_uyari'] = "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/26a0.png" alt="⚠" class="wp-smiley" style="height: 1em; max-height: 1em;" /> 89 EMA Altına Sarkma"
            # AL sinyali varken 89 ve 144 EMA'da aşağı eğim (sinyal bozulmaya başladı)
            elif uzun_durum == 'AL' and (ema89 &lt; ema89_once and ema144 &lt; ema144_once):
                warnings['uzun_uyari'] = "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/26a0.png" alt="⚠" class="wp-smiley" style="height: 1em; max-height: 1em;" /> EMA Eğim Bozulması"

        return warnings

    def determine_signal_status(self, df: pd.DataFrame) -&gt; pd.DataFrame:
        """Sinyal durumlarını belirle - Pine Script<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2122.png" alt="™" class="wp-smiley" style="height: 1em; max-height: 1em;" />'e kurallar güncellendi 16.08.25"""
        df['Kisa_Durum'] = 'BEKLE'
        df['Orta_Durum'] = 'BEKLE'
        df['Uzun_Durum'] = 'BEKLE'
        df['Kisa_Bar_Sayaci'] = 0
        df['Orta_Bar_Sayaci'] = 0
        df['Uzun_Bar_Sayaci'] = 0
        df['Kisa_Sinyal_Tarihi'] = pd.NaT
        df['Orta_Sinyal_Tarihi'] = pd.NaT
        df['Uzun_Sinyal_Tarihi'] = pd.NaT
        df['Kisa_Sinyal_Fiyati'] = pd.NA
        df['Orta_Sinyal_Fiyati'] = pd.NA
        df['Uzun_Sinyal_Fiyati'] = pd.NA

        # Yeni uyarı sütunları
        df['Kisa_Uyari'] = ''
        df['Orta_Uyari'] = ''
        df['Uzun_Uyari'] = ''

        if len(df) &lt; 2:
            return df

        for i in range(1, len(df)):
            kisa_durum_once = df.loc[i - 1, 'Kisa_Durum']
            orta_durum_once = df.loc[i - 1, 'Orta_Durum']
            uzun_durum_once = df.loc[i - 1, 'Uzun_Durum']

            kapanis = df.loc[i, 'Kapanış']

            # KISA VADE SİNYALLERİ - Pine Script<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2122.png" alt="™" class="wp-smiley" style="height: 1em; max-height: 1em;" /> indikatörümüzle uyumlu
            if all(pd.notna(df.loc[i, col]) for col in ['EMA5', 'EMA8', 'EMA13', 'EMA21']) and \
                    all(pd.notna(df.loc[i - 1, col]) for col in ['EMA5', 'EMA8', 'EMA13', 'EMA21']):

                ema5, ema8, ema13, ema21 = df.loc[i, 'EMA5'], df.loc[i, 'EMA8'], df.loc[i, 'EMA13'], df.loc[i, 'EMA21']

                kisa_al_kosulu = (kapanis &gt; ema5 and kapanis &gt; ema8 and kapanis &gt; ema13 and kapanis &gt; ema21)
                kisa_egim_yukari = (ema5 &gt; df.loc[i - 1, 'EMA5'] and ema8 &gt; df.loc[i - 1, 'EMA8'] and
                                    ema13 &gt; df.loc[i - 1, 'EMA13'] and ema21 &gt; df.loc[i - 1, 'EMA21'])

                if kisa_al_kosulu and kisa_egim_yukari:
                    df.loc[i, 'Kisa_Durum'] = "AL"
                    if kisa_durum_once != "AL":
                        df.loc[i, 'Kisa_Bar_Sayaci'] = 1
                        df.loc[i, 'Kisa_Sinyal_Tarihi'] = df.loc[i, 'Tarih']
                        df.loc[i, 'Kisa_Sinyal_Fiyati'] = df.loc[i, 'Kapanış']
                    else:
                        df.loc[i, 'Kisa_Bar_Sayaci'] = df.loc[i - 1, 'Kisa_Bar_Sayaci'] + 1
                        df.loc[i, 'Kisa_Sinyal_Tarihi'] = df.loc[i - 1, 'Kisa_Sinyal_Tarihi']
                        df.loc[i, 'Kisa_Sinyal_Fiyati'] = df.loc[i - 1, 'Kisa_Sinyal_Fiyati']

                else:
                    kisa_egim_asagi = (ema21 &lt; df.loc[i - 1, 'EMA21'] and ema13 &lt; df.loc[i - 1, 'EMA13'])

                    if kapanis &lt; ema21 and kisa_egim_asagi:
                        df.loc[i, 'Kisa_Durum'] = "SAT"
                        if kisa_durum_once != "SAT":
                            df.loc[i, 'Kisa_Bar_Sayaci'] = 1
                            df.loc[i, 'Kisa_Sinyal_Tarihi'] = df.loc[i, 'Tarih']
                            df.loc[i, 'Kisa_Sinyal_Fiyati'] = df.loc[i, 'Kapanış']
                        else:
                            df.loc[i, 'Kisa_Bar_Sayaci'] = df.loc[i - 1, 'Kisa_Bar_Sayaci'] + 1
                            df.loc[i, 'Kisa_Sinyal_Tarihi'] = df.loc[i - 1, 'Kisa_Sinyal_Tarihi']
                            df.loc[i, 'Kisa_Sinyal_Fiyati'] = df.loc[i - 1, 'Kisa_Sinyal_Fiyati']
                    else:
                        # AL sinyalini koruma mantığı
                        if kisa_durum_once == 'AL' and df.loc[i, 'Kisa_Durum'] == 'BEKLE':
                            df.loc[i, 'Kisa_Durum'] = "AL"
                            df.loc[i, 'Kisa_Bar_Sayaci'] = df.loc[i - 1, 'Kisa_Bar_Sayaci'] + 1
                            df.loc[i, 'Kisa_Sinyal_Tarihi'] = df.loc[i - 1, 'Kisa_Sinyal_Tarihi']
                            df.loc[i, 'Kisa_Sinyal_Fiyati'] = df.loc[i - 1, 'Kisa_Sinyal_Fiyati']
                        else:
                            df.loc[i, 'Kisa_Durum'] = "BEKLE"
                            df.loc[i, 'Kisa_Bar_Sayaci'] = 0
                            df.loc[i, 'Kisa_Sinyal_Tarihi'] = pd.NaT
                            df.loc[i, 'Kisa_Sinyal_Fiyati'] = pd.NA

            # ORTA VADE SİNYALLERİ
            if all(col in df.columns for col in ['EMA34', 'EMA55']) and all(
                    pd.notna(df.loc[i, col]) for col in ['EMA34', 'EMA55']):

                ema34 = df.loc[i, 'EMA34']
                ema55 = df.loc[i, 'EMA55']

                if kapanis &gt; ema34 and kapanis &gt; ema55 and ema34 &gt; ema55:
                    df.loc[i, 'Orta_Durum'] = "AL"
                    if orta_durum_once != "AL":
                        df.loc[i, 'Orta_Bar_Sayaci'] = 1
                        df.loc[i, 'Orta_Sinyal_Tarihi'] = df.loc[i, 'Tarih']
                        df.loc[i, 'Orta_Sinyal_Fiyati'] = df.loc[i, 'Kapanış']
                    else:
                        df.loc[i, 'Orta_Bar_Sayaci'] = df.loc[i - 1, 'Orta_Bar_Sayaci'] + 1
                        df.loc[i, 'Orta_Sinyal_Tarihi'] = df.loc[i - 1, 'Orta_Sinyal_Tarihi']
                        df.loc[i, 'Orta_Sinyal_Fiyati'] = df.loc[i - 1, 'Orta_Sinyal_Fiyati']

                elif kapanis &lt; ema55:
                    df.loc[i, 'Orta_Durum'] = "SAT"
                    if orta_durum_once != "SAT":
                        df.loc[i, 'Orta_Bar_Sayaci'] = 1
                        df.loc[i, 'Orta_Sinyal_Tarihi'] = df.loc[i, 'Tarih']
                        df.loc[i, 'Orta_Sinyal_Fiyati'] = df.loc[i, 'Kapanış']
                    else:
                        df.loc[i, 'Orta_Bar_Sayaci'] = df.loc[i - 1, 'Orta_Bar_Sayaci'] + 1
                        df.loc[i, 'Orta_Sinyal_Tarihi'] = df.loc[i - 1, 'Orta_Sinyal_Tarihi']
                        df.loc[i, 'Orta_Sinyal_Fiyati'] = df.loc[i - 1, 'Orta_Sinyal_Fiyati']

                else:
                    df.loc[i, 'Orta_Durum'] = "BEKLE"
                    df.loc[i, 'Orta_Bar_Sayaci'] = 0
                    df.loc[i, 'Orta_Sinyal_Tarihi'] = pd.NaT
                    df.loc[i, 'Orta_Sinyal_Fiyati'] = pd.NA

            # UZUN VADE SİNYALLERİ
            if all(col in df.columns for col in ['EMA89', 'EMA144']) and all(
                    pd.notna(df.loc[i, col]) for col in ['EMA89', 'EMA144']):
                ema89 = df.loc[i, 'EMA89']
                ema144 = df.loc[i, 'EMA144']

                if kapanis &gt; ema89 and kapanis &gt; ema144:
                    df.loc[i, 'Uzun_Durum'] = "AL"
                    if uzun_durum_once != "AL":
                        df.loc[i, 'Uzun_Bar_Sayaci'] = 1
                        df.loc[i, 'Uzun_Sinyal_Tarihi'] = df.loc[i, 'Tarih']
                        df.loc[i, 'Uzun_Sinyal_Fiyati'] = df.loc[i, 'Kapanış']
                    else:
                        df.loc[i, 'Uzun_Bar_Sayaci'] = df.loc[i - 1, 'Uzun_Bar_Sayaci'] + 1
                        df.loc[i, 'Uzun_Sinyal_Tarihi'] = df.loc[i - 1, 'Uzun_Sinyal_Tarihi']
                        df.loc[i, 'Uzun_Sinyal_Fiyati'] = df.loc[i - 1, 'Uzun_Sinyal_Fiyati']

                elif kapanis &lt; ema144:
                    df.loc[i, 'Uzun_Durum'] = "SAT"
                    if uzun_durum_once != "SAT":
                        df.loc[i, 'Uzun_Bar_Sayaci'] = 1
                        df.loc[i, 'Uzun_Sinyal_Tarihi'] = df.loc[i, 'Tarih']
                        df.loc[i, 'Uzun_Sinyal_Fiyati'] = df.loc[i, 'Kapanış']
                    else:
                        df.loc[i, 'Uzun_Bar_Sayaci'] = df.loc[i - 1, 'Uzun_Bar_Sayaci'] + 1
                        df.loc[i, 'Uzun_Sinyal_Tarihi'] = df.loc[i - 1, 'Uzun_Sinyal_Tarihi']
                        df.loc[i, 'Uzun_Sinyal_Fiyati'] = df.loc[i - 1, 'Uzun_Sinyal_Fiyati']

                else:
                    df.loc[i, 'Uzun_Durum'] = "BEKLE"
                    df.loc[i, 'Uzun_Bar_Sayaci'] = 0
                    df.loc[i, 'Uzun_Sinyal_Tarihi'] = pd.NaT
                    df.loc[i, 'Uzun_Sinyal_Fiyati'] = pd.NA

            # SİNYAL BOZULMA UYARILARINI KONTROL ET
            warnings_dict = self.check_signal_deterioration(df, i)
            df.loc[i, 'Kisa_Uyari'] = warnings_dict['kisa_uyari']
            df.loc[i, 'Orta_Uyari'] = warnings_dict['orta_uyari']
            df.loc[i, 'Uzun_Uyari'] = warnings_dict['uzun_uyari']

        return df

    @staticmethod
    def get_latest_signals(df: pd.DataFrame) -&gt; Optional[Dict[str, Any]]:
        """En son sinyal durumlarını getir"""
        if len(df) == 0:
            return None

        latest = df.iloc[-1]

        # Sinyal gücü ataması
        kisa_guc = '<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />' if latest['Kisa_Durum'] != 'BEKLE' else '<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/23f3.png" alt="⏳" class="wp-smiley" style="height: 1em; max-height: 1em;" />'
        orta_guc = '<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />' if latest['Orta_Durum'] != 'BEKLE' else '<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/23f3.png" alt="⏳" class="wp-smiley" style="height: 1em; max-height: 1em;" />'
        uzun_guc = '<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />' if latest['Uzun_Durum'] != 'BEKLE' else '<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/23f3.png" alt="⏳" class="wp-smiley" style="height: 1em; max-height: 1em;" />'

        # Fiyat farkı hesaplamaları
        kisa_fark_tl = latest['Kapanış'] - latest['Kisa_Sinyal_Fiyati'] if pd.notna(
            latest['Kisa_Sinyal_Fiyati']) else pd.NA
        kisa_fark_yuzde = (kisa_fark_tl / latest['Kisa_Sinyal_Fiyati']) * 100 if pd.notna(kisa_fark_tl) else pd.NA

        orta_fark_tl = latest['Kapanış'] - latest['Orta_Sinyal_Fiyati'] if pd.notna(
            latest['Orta_Sinyal_Fiyati']) else pd.NA
        orta_fark_yuzde = (orta_fark_tl / latest['Orta_Sinyal_Fiyati']) * 100 if pd.notna(orta_fark_tl) else pd.NA

        uzun_fark_tl = latest['Kapanış'] - latest['Uzun_Sinyal_Fiyati'] if pd.notna(
            latest['Uzun_Sinyal_Fiyati']) else pd.NA
        uzun_fark_yuzde = (uzun_fark_tl / latest['Uzun_Sinyal_Fiyati']) * 100 if pd.notna(uzun_fark_tl) else pd.NA

        # NaN değerler yerine 'Yok' metnini kullanma
        def format_value(value, format_str, default='Yok'):
            if pd.notna(value):
                return format_str.format(value)
            return default

        return {
            'tarih': latest['Tarih'].strftime('%Y-%m-%d'),
            'kapanis': latest['Kapanış'],
            'kisa': {
                'durum': latest['Kisa_Durum'],
                'bar_sayaci': latest['Kisa_Bar_Sayaci'],
                'sinyal_tarihi': format_value(latest['Kisa_Sinyal_Tarihi'], '{:%d.%m.%Y}'),
                'sinyal_fiyati': format_value(latest['Kisa_Sinyal_Fiyati'], '{:.2f}'),
                'fark_tl': format_value(kisa_fark_tl, '{:.2f}'),
                'fark_yuzde': format_value(kisa_fark_yuzde, '{:.2f}%'),
                'guc': kisa_guc,
                'uyari': latest['Kisa_Uyari'] if 'Kisa_Uyari' in df.columns else ''
            },
            'orta': {
                'durum': latest['Orta_Durum'],
                'bar_sayaci': latest['Orta_Bar_Sayaci'],
                'sinyal_tarihi': format_value(latest['Orta_Sinyal_Tarihi'], '{:%d.%m.%Y}'),
                'sinyal_fiyati': format_value(latest['Orta_Sinyal_Fiyati'], '{:.2f}'),
                'fark_tl': format_value(orta_fark_tl, '{:.2f}'),
                'fark_yuzde': format_value(orta_fark_yuzde, '{:.2f}%'),
                'guc': orta_guc,
                'uyari': latest['Orta_Uyari'] if 'Orta_Uyari' in df.columns else ''
            },
            'uzun': {
                'durum': latest['Uzun_Durum'],
                'bar_sayaci': latest['Uzun_Bar_Sayaci'],
                'sinyal_tarihi': format_value(latest['Uzun_Sinyal_Tarihi'], '{:%d.%m.%Y}'),
                'sinyal_fiyati': format_value(latest['Uzun_Sinyal_Fiyati'], '{:.2f}'),
                'fark_tl': format_value(uzun_fark_tl, '{:.2f}'),
                'fark_yuzde': format_value(uzun_fark_yuzde, '{:.2f}%'),
                'guc': uzun_guc,
                'uyari': latest['Uzun_Uyari'] if 'Uzun_Uyari' in df.columns else ''
            }
        }

    def process_single_stock(self, file_path: str) -&gt; Optional[Dict[str, Any]]:
        """Tek bir hisse için EMA analizi yap ve sonuçları topla"""
        ticker_name = os.path.splitext(os.path.basename(file_path))[0]
        print(f"{Fore.YELLOW} EMA sinyalleri hesaplanıyor: {ticker_name}...")

        try:
            df = self.load_stock_data(file_path)

            # En az kısa vade EMA için yeterli veri yoksa hata ver
            if df.empty or len(df) &lt; min(self.ema_periods['kisa_vade']):
                raise ValueError("Yeterli veri yok veya dosya geçersiz.")

            # Tüm EMA'ları ve sinyalleri hesapla
            df = self.calculate_all_emas(df)
            df = self.determine_signal_status(df)

            latest_signals = self.get_latest_signals(df)

            if latest_signals:
                self.successful_files.append(ticker_name)
                latest_signals['hisse'] = ticker_name
                print(f"{Fore.GREEN}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2705.png" alt="✅" class="wp-smiley" style="height: 1em; max-height: 1em;" /> {ticker_name} için analiz başarılı.")
            else:
                self.failed_files.append(ticker_name)
                print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> {ticker_name} için sinyal oluşturulamadı.")

            return latest_signals

        except (ValueError, pd.errors.ParserError) as e:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> {ticker_name} için hata: {e}")
            self.failed_files.append(ticker_name)
            return None

    def main(self):
        """Ana fonksiyon"""
        print(f"{Fore.CYAN} BorsaPin EMA Analiz Sistemi Başlatılıyor...")

        input_folder = "StokData/Kapanis/"
        input_files = glob.glob(os.path.join(input_folder, "*.xlsx"))

        if not input_files:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> {input_folder} klasöründe Excel dosyası bulunamadı!")
            return

        all_latest_results: List[Dict[str, Any]] = []
        for i, file_path in enumerate(input_files, 1):
            print(f"\n{Fore.MAGENTA}[{i}/{len(input_files)}] İşleniyor...")
            latest_signals = self.process_single_stock(file_path)
            if latest_signals:
                all_latest_results.append(latest_signals)

        if all_latest_results:
            self.save_all_signals_to_excel(all_latest_results)

        self.print_summary()
        self.save_failed_list()

        print(f"\n{Fore.GREEN} EMA analiz işlemi tamamlandı!")

    def save_all_signals_to_excel(self, results: List[Dict[str, Any]]):
        """Tüm sinyalleri tek bir Excel dosyasına farklı sayfalarda kaydet"""
        output_folder = "StokData/"
        os.makedirs(output_folder, exist_ok=True)
        filename = os.path.join(output_folder, "BorsaPin_EMA_Analizleri.xlsx")

        summary_df = self.create_summary_table(results)
        strong_signals_df = self.filter_strong_signals_df(summary_df)
        warning_signals_df = self.filter_warning_signals_df(summary_df)

        # Detaylı sinyal tabloları oluştur
        kisa_vade_df = self.create_detailed_signal_table(results, 'kisa')
        orta_vade_df = self.create_detailed_signal_table(results, 'orta')
        uzun_vade_df = self.create_detailed_signal_table(results, 'uzun')

        # İstatistik tabloları oluştur
        statistics_df = self.create_statistics_table(results)

        with pd.ExcelWriter(filename, engine='openpyxl') as writer:
            # Ana özet sayfası
            if not summary_df.empty:
                summary_df.to_excel(writer, sheet_name='Genel Özet', index=False)
                self.format_worksheet(writer.sheets['Genel Özet'], summary_df)

            # Güçlü sinyaller sayfası
            if not strong_signals_df.empty:
                strong_signals_df.to_excel(writer, sheet_name='Güçlü Sinyaller', index=False)
                self.format_worksheet(writer.sheets['Güçlü Sinyaller'], strong_signals_df)

            # Uyarı sinyalleri sayfası
            if not warning_signals_df.empty:
                warning_signals_df.to_excel(writer, sheet_name='Uyarı Sinyalleri', index=False)
                self.format_worksheet(writer.sheets['Uyarı Sinyalleri'], warning_signals_df)

            # Detaylı vade sayfaları
            if not kisa_vade_df.empty:
                kisa_vade_df.to_excel(writer, sheet_name='Kısa Vade Detay', index=False)
                self.format_worksheet(writer.sheets['Kısa Vade Detay'], kisa_vade_df)

            if not orta_vade_df.empty:
                orta_vade_df.to_excel(writer, sheet_name='Orta Vade Detay', index=False)
                self.format_worksheet(writer.sheets['Orta Vade Detay'], orta_vade_df)

            if not uzun_vade_df.empty:
                uzun_vade_df.to_excel(writer, sheet_name='Uzun Vade Detay', index=False)
                self.format_worksheet(writer.sheets['Uzun Vade Detay'], uzun_vade_df)

            # İstatistik sayfası
            if not statistics_df.empty:
                statistics_df.to_excel(writer, sheet_name='İstatistikler', index=False)
                self.format_worksheet(writer.sheets['İstatistikler'], statistics_df)

        print(f"{Fore.GREEN}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2705.png" alt="✅" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Tüm analiz sonuçları başarıyla kaydedildi: {filename}")

    @staticmethod
    def create_summary_table(results: List[Dict[str, Any]]) -&gt; pd.DataFrame:
        """Özet Tablolar """
        summary_data = [
            {
                'Hisse': res['hisse'],
                'Kapanış': round(res['kapanis'], 2),
                'Kısa Vade': res['kisa']['durum'],
                'Kısa Uyarı': res['kisa']['uyari'],
                'Sinyal Süresi': res['kisa']['bar_sayaci'],
                'Kısa Vade Sinyal Tarihi': res['kisa']['sinyal_tarihi'],
                'Kısa Vade Sinyal Fiyatı': res['kisa']['sinyal_fiyati'],
                'Kısa Vade Kazanç TL': res['kisa']['fark_tl'],
                'Kısa Vade Kazanç %': res['kisa']['fark_yuzde'],
                'Orta Vade': res['orta']['durum'],
                'Orta Uyarı': res['orta']['uyari'],
                'Orta Sinyal Süresi': res['orta']['bar_sayaci'],
                'Orta Vade Sinyal Tarihi': res['orta']['sinyal_tarihi'],
                'Orta Vade Sinyal Fiyatı': res['orta']['sinyal_fiyati'],
                'Orta Vade Kazanç TL': res['orta']['fark_tl'],
                'Orta Vade Kazanç %': res['orta']['fark_yuzde'],
                'Uzun Vade': res['uzun']['durum'],
                'Uzun Uyarı': res['uzun']['uyari'],
                'Uzun Sinyal Süresi': res['uzun']['bar_sayaci'],
                'Uzun Vade Sinyal Tarihi': res['uzun']['sinyal_tarihi'],
                'Uzun Vade Sinyal Fiyatı': res['uzun']['sinyal_fiyati'],
                'Uzun Vade Kazanç TL': res['uzun']['fark_tl'],
                'Uzun Vade Kazanç %': res['uzun']['fark_yuzde']
            } for res in results
        ]
        return pd.DataFrame(summary_data)

    @staticmethod
    def create_detailed_signal_table(results: List[Dict[str, Any]], vade_type: str) -&gt; pd.DataFrame:
        """Belirli vade için detaylı sinyal tablosu oluştur"""
        detailed_data = []
        for res in results:
            vade_data = res[vade_type]
            if vade_data['durum'] != 'BEKLE':
                detailed_data.append({
                    'Hisse': res['hisse'],
                    'Kapanış': round(res['kapanis'], 2),
                    'Sinyal Durumu': vade_data['durum'],
                    'Uyarı Durumu': vade_data['uyari'],
                    'Sinyal Süresi (Gün)': vade_data['bar_sayaci'],
                    'Sinyal Tarihi': vade_data['sinyal_tarihi'],
                    'Sinyal Fiyatı': vade_data['sinyal_fiyati'],
                    'Kazanç/Kayıp TL': vade_data['fark_tl'],
                    'Kazanç/Kayıp %': vade_data['fark_yuzde']
                })

        df = pd.DataFrame(detailed_data)
        if not df.empty:
            # Sinyal süresine göre sırala (en uzun süreli sinyaller önce)
            df = df.sort_values('Sinyal Süresi (Gün)', ascending=False).reset_index(drop=True)

        return df

    @staticmethod
    def filter_warning_signals_df(summary_df: pd.DataFrame) -&gt; pd.DataFrame:
        """Uyarı sinyali olan hisseleri filtreleme"""
        if summary_df.empty:
            return pd.DataFrame()

        warning_signals_df = summary_df[
            (summary_df['Kısa Uyarı'] != '') |
            (summary_df['Orta Uyarı'] != '') |
            (summary_df['Uzun Uyarı'] != '')
            ].reset_index(drop=True)

        return warning_signals_df

    @staticmethod
    def create_statistics_table(results: List[Dict[str, Any]]) -&gt; pd.DataFrame:
        """İstatistik tablosu"""
        stats_data = []

        # Genel istatistikler
        total_stocks = len(results)

        # Her vade için istatistikler
        for vade_key, vade_name in [('kisa', 'Kısa Vade'), ('orta', 'Orta Vade'), ('uzun', 'Uzun Vade')]:
            al_sinyali = sum(1 for res in results if res[vade_key]['durum'] == 'AL')
            sat_sinyali = sum(1 for res in results if res[vade_key]['durum'] == 'SAT')
            bekle_sinyali = sum(1 for res in results if res[vade_key]['durum'] == 'BEKLE')
            uyari_sinyali = sum(1 for res in results if res[vade_key]['uyari'] != '')

            # Ortalama sinyal süresi (sadece aktif sinyaller için)
            aktif_sinyaller = [res[vade_key]['bar_sayaci'] for res in results
                               if res[vade_key]['durum'] != 'BEKLE' and res[vade_key]['bar_sayaci'] &gt; 0]
            ortalama_sure = round(sum(aktif_sinyaller) / len(aktif_sinyaller), 1) if aktif_sinyaller else 0

            # En uzun sinyal süresi
            max_sure = max(aktif_sinyaller) if aktif_sinyaller else 0

            # Pozitif/negatif performans (sadece AL sinyalleri için)
            al_sinyalleri = [res for res in results if res[vade_key]['durum'] == 'AL']
            pozitif_performans = 0
            negatif_performans = 0

            for res in al_sinyalleri:
                try:
                    fark_str = res[vade_key]['fark_yuzde']
                    if fark_str != 'Yok' and '%' in fark_str:
                        fark_value = float(fark_str.replace('%', ''))
                        if fark_value &gt; 0:
                            pozitif_performans += 1
                        else:
                            negatif_performans += 1
                except ValueError:
                    pass

            stats_data.extend([
                {
                    'Vade Türü': vade_name,
                    'Metrik': 'Toplam Hisse Sayısı',
                    'Değer': total_stocks,
                    'Oran %': '100.0'
                },
                {
                    'Vade Türü': vade_name,
                    'Metrik': 'AL Sinyali',
                    'Değer': al_sinyali,
                    'Oran %': f"{(al_sinyali / total_stocks * 100):.1f}" if total_stocks &gt; 0 else "0.0"
                },
                {
                    'Vade Türü': vade_name,
                    'Metrik': 'SAT Sinyali',
                    'Değer': sat_sinyali,
                    'Oran %': f"{(sat_sinyali / total_stocks * 100):.1f}" if total_stocks &gt; 0 else "0.0"
                },
                {
                    'Vade Türü': vade_name,
                    'Metrik': 'BEKLE Durumu',
                    'Değer': bekle_sinyali,
                    'Oran %': f"{(bekle_sinyali / total_stocks * 100):.1f}" if total_stocks &gt; 0 else "0.0"
                },
                {
                    'Vade Türü': vade_name,
                    'Metrik': 'Uyarı Sinyali',
                    'Değer': uyari_sinyali,
                    'Oran %': f"{(uyari_sinyali / total_stocks * 100):.1f}" if total_stocks &gt; 0 else "0.0"
                },
                {
                    'Vade Türü': vade_name,
                    'Metrik': 'Ortalama Sinyal Süresi (Gün)',
                    'Değer': ortalama_sure,
                    'Oran %': '-'
                },
                {
                    'Vade Türü': vade_name,
                    'Metrik': 'En Uzun Sinyal Süresi (Gün)',
                    'Değer': max_sure,
                    'Oran %': '-'
                },
                {
                    'Vade Türü': vade_name,
                    'Metrik': 'Pozitif Performans (AL)',
                    'Değer': pozitif_performans,
                    'Oran %': f"{(pozitif_performans / al_sinyali * 100):.1f}" if al_sinyali &gt; 0 else "0.0"
                },
                {
                    'Vade Türü': vade_name,
                    'Metrik': 'Negatif Performans (AL)',
                    'Değer': negatif_performans,
                    'Oran %': f"{(negatif_performans / al_sinyali * 100):.1f}" if al_sinyali &gt; 0 else "0.0"
                }
            ])

        # Güçlü sinyaller (tüm vadeler AL)
        guclu_sinyaller = sum(1 for res in results
                              if res['kisa']['durum'] == 'AL' and
                              res['orta']['durum'] == 'AL' and
                              res['uzun']['durum'] == 'AL')

        # Toplam uyarı sinyalleri
        toplam_uyari = sum(1 for res in results
                           if res['kisa']['uyari'] != '' or
                           res['orta']['uyari'] != '' or
                           res['uzun']['uyari'] != '')

        stats_data.extend([
            {
                'Vade Türü': 'Genel',
                'Metrik': 'Güçlü Sinyal (Tüm Vadeler AL)',
                'Değer': guclu_sinyaller,
                'Oran %': f"{(guclu_sinyaller / total_stocks * 100):.1f}" if total_stocks &gt; 0 else "0.0"
            },
            {
                'Vade Türü': 'Genel',
                'Metrik': 'Toplam Uyarı Sinyali',
                'Değer': toplam_uyari,
                'Oran %': f"{(toplam_uyari / total_stocks * 100):.1f}" if total_stocks &gt; 0 else "0.0"
            }
        ])

        return pd.DataFrame(stats_data)

    @staticmethod
    def format_worksheet(worksheet, df):
        """Excel çalışma sayfası formatları """
        try:
            # Başlık satırı formatı
            header_fill = PatternFill(start_color='366092', end_color='366092', fill_type='solid')
            header_font = Font(color='FFFFFF', bold=True)
            header_alignment = Alignment(horizontal='center', vertical='center')

            # Kenarlık stili
            thin_border = Border(
                left=Side(style='thin'),
                right=Side(style='thin'),
                top=Side(style='thin'),
                bottom=Side(style='thin')
            )

            # Başlık satırını formatla
            for col_num, column_title in enumerate(df.columns, 1):
                cell = worksheet.cell(row=1, column=col_num)
                cell.fill = header_fill
                cell.font = header_font
                cell.alignment = header_alignment
                cell.border = thin_border

            # Veri satırlarını formatla
            for row_num in range(2, len(df) + 2):
                for col_num in range(1, len(df.columns) + 1):
                    cell = worksheet.cell(row=row_num, column=col_num)
                    cell.border = thin_border
                    cell.alignment = Alignment(horizontal='center', vertical='center')

            # Sütun genişliklerini ayarla
            for column in worksheet.columns:
                max_length = 0
                column_letter = column[0].column_letter

                for cell in column:
                    try:
                        if len(str(cell.value)) &gt; max_length:
                            max_length = len(str(cell.value))
                    except (TypeError, ValueError):
                        pass

                adjusted_width = min(max_length + 2, 20)
                worksheet.column_dimensions[column_letter].width = adjusted_width

            # Freeze panes ve autofilter
            worksheet.freeze_panes = 'A2'
            worksheet.auto_filter.ref = worksheet.dimensions

            # Sinyal durumu sütunları için renk kodlaması
            for row_num in range(2, len(df) + 2):
                for col_num, column_name in enumerate(df.columns, 1):
                    cell = worksheet.cell(row=row_num, column=col_num)

                    # Ana özet sayfaları için vade sütunları
                    if 'Vade' in column_name and column_name.endswith('Vade'):
                        if cell.value == 'AL':
                            cell.fill = PatternFill(start_color='90EE90', end_color='90EE90', fill_type='solid')
                            cell.font = Font(bold=True, color='006400')
                        elif cell.value == 'SAT':
                            cell.fill = PatternFill(start_color='FFB6C1', end_color='FFB6C1', fill_type='solid')
                            cell.font = Font(bold=True, color='8B0000')
                        elif cell.value == 'BEKLE':
                            cell.fill = PatternFill(start_color='FFFFE0', end_color='FFFFE0', fill_type='solid')
                            cell.font = Font(bold=True, color='B8860B')

                    # Detay sayfaları için "Sinyal Durumu" sütunu
                    elif column_name == 'Sinyal Durumu':
                        if cell.value == 'AL':
                            cell.fill = PatternFill(start_color='90EE90', end_color='90EE90', fill_type='solid')
                            cell.font = Font(bold=True, color='006400')
                        elif cell.value == 'SAT':
                            cell.fill = PatternFill(start_color='FFB6C1', end_color='FFB6C1', fill_type='solid')
                            cell.font = Font(bold=True, color='8B0000')

                    # Uyarı sütunları için renk kodlaması
                    elif 'Uyarı' in column_name:
                        if cell.value and cell.value != '':
                            cell.fill = PatternFill(start_color='FFA500', end_color='FFA500', fill_type='solid')
                            cell.font = Font(bold=True, color='FFFFFF')

                    # Uyarı durumu sütunu için renk kodlaması
                    elif column_name == 'Uyarı Durumu':
                        if cell.value and cell.value != '':
                            cell.fill = PatternFill(start_color='FFA500', end_color='FFA500', fill_type='solid')
                            cell.font = Font(bold=True, color='FFFFFF')

                    # Kazanç/Kayıp yüzde değerleri için renk kodlaması
                    elif 'Kazanç' in column_name and '%' in column_name:
                        try:
                            if cell.value and cell.value != 'Yok' and '%' in str(cell.value):
                                percentage_value = float(str(cell.value).replace('%', ''))
                                if percentage_value &gt; 0:
                                    cell.fill = PatternFill(start_color='E6FFE6', end_color='E6FFE6', fill_type='solid')
                                    cell.font = Font(color='006400', bold=True)
                                elif percentage_value &lt; 0:
                                    cell.fill = PatternFill(start_color='FFE6E6', end_color='FFE6E6', fill_type='solid')
                                    cell.font = Font(color='8B0000', bold=True)
                        except (ValueError, TypeError):
                            pass

                    # Kazanç/Kayıp TL değerleri için renk kodlaması
                    elif 'Kazanç' in column_name and 'TL' in column_name:
                        try:
                            if cell.value and cell.value != 'Yok':
                                tl_value = float(str(cell.value))
                                if tl_value &gt; 0:
                                    cell.fill = PatternFill(start_color='E6FFE6', end_color='E6FFE6', fill_type='solid')
                                    cell.font = Font(color='006400', bold=True)
                                elif tl_value &lt; 0:
                                    cell.fill = PatternFill(start_color='FFE6E6', end_color='FFE6E6', fill_type='solid')
                                    cell.font = Font(color='8B0000', bold=True)
                        except (ValueError, TypeError):
                            pass

                    # Sinyal süresi için renk gradyanı (uzun süreli sinyaller daha koyu)
                    elif 'Sinyal Süresi' in column_name or 'Sinyal Süresi (Gün)' in column_name:
                        try:
                            if cell.value and isinstance(cell.value, (int, float)) and cell.value &gt; 0:
                                days = int(cell.value)
                                if days &gt;= 30:
                                    cell.fill = PatternFill(start_color='4CAF50', end_color='4CAF50', fill_type='solid')
                                    cell.font = Font(color='FFFFFF', bold=True)
                                elif days &gt;= 14:
                                    cell.fill = PatternFill(start_color='8BC34A', end_color='8BC34A', fill_type='solid')
                                    cell.font = Font(color='FFFFFF', bold=True)
                                elif days &gt;= 7:
                                    cell.fill = PatternFill(start_color='CDDC39', end_color='CDDC39', fill_type='solid')
                                    cell.font = Font(color='333333', bold=True)
                                elif days &gt;= 3:
                                    cell.fill = PatternFill(start_color='FFF176', end_color='FFF176', fill_type='solid')
                                    cell.font = Font(color='333333', bold=True)
                        except (ValueError, TypeError):
                            pass
        except Exception as e:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Excel formatlama hatası: {e}")

    @staticmethod
    def filter_strong_signals_df(summary_df: pd.DataFrame) -&gt; pd.DataFrame:
        """Tüm vadelerde 'AL' sinyali olan hisseleri filtrele"""
        if summary_df.empty:
            return pd.DataFrame()
        strong_signals_df = summary_df[
            (summary_df['Kısa Vade'] == 'AL') &amp;
            (summary_df['Orta Vade'] == 'AL') &amp;
            (summary_df['Uzun Vade'] == 'AL')
            ].reset_index(drop=True)
        return strong_signals_df

    def print_summary(self):
        """İşlem özetini ekrana yazdır"""
        total_files = len(self.successful_files) + len(self.failed_files)
        print("\n" + "=" * 40)
        print(f"{Fore.CYAN}BorsaPin EMA Analizi Özeti")
        print("=" * 40)
        print(f"{Fore.GREEN}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2705.png" alt="✅" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Başarılı Analiz Edilen Hisse Sayısı: {len(self.successful_files)} / {total_files}")
        if self.successful_files:
            print(f"{Fore.GREEN}  - Hisse Listesi: {', '.join(self.successful_files)}")
        print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Hata Alan Hisse Sayısı: {len(self.failed_files)} / {total_files}")
        if self.failed_files:
            print(f"{Fore.RED}  - Hisse Listesi: {', '.join(self.failed_files)}")
        print("=" * 40)

    def save_failed_list(self):
        """Hata veren hisseleri bir dosyaya kaydet"""
        if self.failed_files:
            with open("StokData/hata_veren_hisseler.txt", "w") as f:
                f.write("\n".join(self.failed_files))
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Hata veren hisse listesi 'StokData/hata_veren_hisseler.txt' dosyasına kaydedildi.")


if __name__ == "__main__":
    analyzer = BorsaPinEMAAnalyzer()
    analyzer.main()</pre>
<p>&nbsp;</p><p>The post <a href="https://www.kursatsenturk.com/2025/08/python-ile-otomatik-ema-sinyal-analizi-kisa-orta-ve-uzun-vadeli-alim-stratejileri.html">Python ile Otomatik EMA Sinyal Analizi: Kısa, Orta ve Uzun Vadeli Alım Stratejileri</a> first appeared on <a href="https://www.kursatsenturk.com">SDC</a>.</p>]]></content:encoded>
					
					<wfw:commentRss>https://www.kursatsenturk.com/2025/08/python-ile-otomatik-ema-sinyal-analizi-kisa-orta-ve-uzun-vadeli-alim-stratejileri.html/feed</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			<enclosure length="209192" type="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet" url="https://www.kursatsenturk.com/wp-content/uploads/2025/08/BorsaPin_EMA_Analizleri.xlsx"/><itunes:explicit>no</itunes:explicit><itunes:subtitle>Betik Güncellendi 16.08.25 v1.02 Bu Python kodu, hisse senedi yatırımcıları için tasarlanmış, EMA (Üssel Hareketli Ortalama) tabanlı bir sinyal analiz sistemidir. Kod, her hisse için farklı vadelere özel sinyal üretir ve bu sinyallerin nasıl oluşup sonlandığını titizlikle takip eder. Kodun kısa, orta ve uzun vadeli sinyal mantığına dair detaylar şu şekilde Kısa Vade Sinyalleri (EMA [&amp;#8230;] The post Python ile Otomatik EMA Sinyal Analizi: Kısa, Orta ve Uzun Vadeli Alım Stratejileri first appeared on SDC.</itunes:subtitle><itunes:summary>Betik Güncellendi 16.08.25 v1.02 Bu Python kodu, hisse senedi yatırımcıları için tasarlanmış, EMA (Üssel Hareketli Ortalama) tabanlı bir sinyal analiz sistemidir. Kod, her hisse için farklı vadelere özel sinyal üretir ve bu sinyallerin nasıl oluşup sonlandığını titizlikle takip eder. Kodun kısa, orta ve uzun vadeli sinyal mantığına dair detaylar şu şekilde Kısa Vade Sinyalleri (EMA [&amp;#8230;] The post Python ile Otomatik EMA Sinyal Analizi: Kısa, Orta ve Uzun Vadeli Alım Stratejileri first appeared on SDC.</itunes:summary><itunes:keywords>BorsaPin, Python, Teknik Analiz, algoritmik trading, alım satım sinyalleri, borsa, borsa otomasyonu, Ema, excel raporlama, hisse senedi analizi, kısa vade, orta vade, otomatik analiz, pin bar, Pine Script, sinyal takibi, trend takibi, üssel hareketli ortalama, uzun vade, yatırım stratejisi</itunes:keywords></item>
		<item>
		<title>Kod gösterimleri ile ilgili sıkıntı</title>
		<link>https://www.kursatsenturk.com/2025/08/kod-gosterimleri-ile-ilgili-sikinti.html</link>
					<comments>https://www.kursatsenturk.com/2025/08/kod-gosterimleri-ile-ilgili-sikinti.html#respond</comments>
		
		<dc:creator><![CDATA[sdc]]></dc:creator>
		<pubDate>Sun, 10 Aug 2025 22:41:17 +0000</pubDate>
				<category><![CDATA[BorsaPin]]></category>
		<category><![CDATA[Code is prority]]></category>
		<category><![CDATA[İndikatör]]></category>
		<category><![CDATA[Pine Script]]></category>
		<category><![CDATA[Python]]></category>
		<category><![CDATA[Teknik Analiz]]></category>
		<guid isPermaLink="false">https://www.kursatsenturk.com/?p=11473</guid>

					<description><![CDATA[<p>Paylaştığım kodlarda sıkıntı yaşarsanız Google Drive Alanından indirmeniz daha iyi olur. Sitedeki kod gösterici eklentide ufak bir problem vardı. Bu sorunu başka bir plugingle çözdüm ve yazıların bir çoğunu güncelledim ama gözden kaçan düzenlenmemiş Python betiği yada Trading View Pine Script kodlarında sıkıntı olabilir.Eğer sorun yaşarsanız yazının altına yorum yazarsanız tekrar gözden geçiririm.  Borsapin Python [&#8230;]</p>
<p>The post <a href="https://www.kursatsenturk.com/2025/08/kod-gosterimleri-ile-ilgili-sikinti.html">Kod gösterimleri ile ilgili sıkıntı</a> first appeared on <a href="https://www.kursatsenturk.com">SDC</a>.</p>]]></description>
										<content:encoded><![CDATA[<p class="wp-block-paragraph"><a href="https://www.kursatsenturk.com/wp-content/uploads/2025/07/1_37nudw5YFzaQOo3RYcKrZA.png"><img loading="lazy" decoding="async" class="aligncenter size-full wp-image-11227" src="https://www.kursatsenturk.com/wp-content/uploads/2025/07/1_37nudw5YFzaQOo3RYcKrZA.png" alt="" width="777" height="548" srcset="https://www.kursatsenturk.com/wp-content/uploads/2025/07/1_37nudw5YFzaQOo3RYcKrZA.png 777w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/1_37nudw5YFzaQOo3RYcKrZA-300x212.png 300w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/1_37nudw5YFzaQOo3RYcKrZA-768x542.png 768w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/1_37nudw5YFzaQOo3RYcKrZA-679x479.png 679w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/1_37nudw5YFzaQOo3RYcKrZA-262x185.png 262w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/1_37nudw5YFzaQOo3RYcKrZA-574x405.png 574w" sizes="auto, (max-width: 777px) 100vw, 777px" /></a><br /><br />Paylaştığım kodlarda sıkıntı yaşarsanız Google Drive Alanından indirmeniz daha iyi olur. Sitedeki kod gösterici eklentide ufak bir problem vardı. Bu sorunu başka bir plugingle çözdüm ve yazıların bir çoğunu güncelledim ama gözden kaçan düzenlenmemiş Python betiği yada Trading View Pine Script kodlarında sıkıntı olabilir.<br />Eğer sorun yaşarsanız yazının altına yorum yazarsanız tekrar gözden geçiririm. <br /><br /><br /><a href="https://drive.google.com/drive/folders/1AZLUYFRpqI1cUFvA2LOWDKcnSCQ1e7nq" target="_blank" rel="noopener">Borsapin Python Bist Tarama  ve Trading View Pine Script İndikatörleri için Google Drive alanı için buraya tıklayabilirsiniz.</a><br /><br /></p>



<p class="wp-block-paragraph">&nbsp;</p><p>The post <a href="https://www.kursatsenturk.com/2025/08/kod-gosterimleri-ile-ilgili-sikinti.html">Kod gösterimleri ile ilgili sıkıntı</a> first appeared on <a href="https://www.kursatsenturk.com">SDC</a>.</p>]]></content:encoded>
					
					<wfw:commentRss>https://www.kursatsenturk.com/2025/08/kod-gosterimleri-ile-ilgili-sikinti.html/feed</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>Borsapin EMA Sinyal Tablosu (Kısa, Orta, Uzun Vade)</title>
		<link>https://www.kursatsenturk.com/2025/08/borsapin-ema-sinyal-tablosu-kisa-orta-uzun-vade.html</link>
					<comments>https://www.kursatsenturk.com/2025/08/borsapin-ema-sinyal-tablosu-kisa-orta-uzun-vade.html#respond</comments>
		
		<dc:creator><![CDATA[sdc]]></dc:creator>
		<pubDate>Sun, 10 Aug 2025 12:22:06 +0000</pubDate>
				<category><![CDATA[BorsaPin]]></category>
		<category><![CDATA[Teknik Analiz]]></category>
		<category><![CDATA[Trading View]]></category>
		<category><![CDATA[al sat sinyali]]></category>
		<category><![CDATA[algoritmik trading]]></category>
		<category><![CDATA[aylık analiz]]></category>
		<category><![CDATA[backtesting]]></category>
		<category><![CDATA[borsa eğitimi]]></category>
		<category><![CDATA[borsa sinyali]]></category>
		<category><![CDATA[çoklu varlık analizi]]></category>
		<category><![CDATA[çoklu zaman dilimi analizi]]></category>
		<category><![CDATA[day trading]]></category>
		<category><![CDATA[destek direnç]]></category>
		<category><![CDATA[ema crossover]]></category>
		<category><![CDATA[fibonacci ema]]></category>
		<category><![CDATA[fibonacci sayıları]]></category>
		<category><![CDATA[grafik analizi]]></category>
		<category><![CDATA[günlük analiz]]></category>
		<category><![CDATA[hacim analizi]]></category>
		<category><![CDATA[haftalık analiz]]></category>
		<category><![CDATA[hisse senedi analizi]]></category>
		<category><![CDATA[kısa vade sinyali]]></category>
		<category><![CDATA[kripto para analizi]]></category>
		<category><![CDATA[momentum indikatörü]]></category>
		<category><![CDATA[orta vade sinyali]]></category>
		<category><![CDATA[otomatik sinyal]]></category>
		<category><![CDATA[performans analizi]]></category>
		<category><![CDATA[Pine Script]]></category>
		<category><![CDATA[piyasa analizi]]></category>
		<category><![CDATA[piyasa momentumu]]></category>
		<category><![CDATA[portföy yönetimi]]></category>
		<category><![CDATA[pozisyon trading]]></category>
		<category><![CDATA[quantitative analysis]]></category>
		<category><![CDATA[risk yönetimi]]></category>
		<category><![CDATA[sinyal tablosu]]></category>
		<category><![CDATA[Stop-Loss]]></category>
		<category><![CDATA[swing trading]]></category>
		<category><![CDATA[teknik indikatör]]></category>
		<category><![CDATA[trading stratejisi]]></category>
		<category><![CDATA[tradingview indikatörü]]></category>
		<category><![CDATA[tradingview kodu]]></category>
		<category><![CDATA[trend analizi]]></category>
		<category><![CDATA[trend takibi]]></category>
		<category><![CDATA[Üstel Hareketli Ortalama]]></category>
		<category><![CDATA[uzun vade sinyali]]></category>
		<category><![CDATA[volatilite analizi]]></category>
		<category><![CDATA[yatırım stratejisi]]></category>
		<guid isPermaLink="false">https://www.kursatsenturk.com/?p=11451</guid>

					<description><![CDATA[<p>Teknik analizde hareketli ortalamalar, piyasanın genel trendini ve momentum değişimlerini anlamak için kullanılan en temel araçlardan biridir. Borsapin EMA Sinyal Tablosu, Fibonacci sayı dizisine dayalı EMA (Üstel Hareketli Ortalama) sistemini kullanarak yatırımcılara üç farklı zaman diliminde (kısa, orta, uzun vade) sinyal üreten gelişmiş bir indikatördür. Fibonacci EMA Serileri Kısa Vade EMA&#8217;lar: 5, 8, 13, 21 [&#8230;]</p>
<p>The post <a href="https://www.kursatsenturk.com/2025/08/borsapin-ema-sinyal-tablosu-kisa-orta-uzun-vade.html">Borsapin EMA Sinyal Tablosu (Kısa, Orta, Uzun Vade)</a> first appeared on <a href="https://www.kursatsenturk.com">SDC</a>.</p>]]></description>
										<content:encoded><![CDATA[<p><a href="https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw.png"><img loading="lazy" decoding="async" class="aligncenter size-full wp-image-11505" src="https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw.png" alt="" width="777" height="548" srcset="https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw.png 777w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw-300x212.png 300w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw-768x542.png 768w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw-679x479.png 679w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw-262x185.png 262w, https://www.kursatsenturk.com/wp-content/uploads/2025/07/Borsapintw-574x405.png 574w" sizes="auto, (max-width: 777px) 100vw, 777px" /></a></p>
<p>Teknik analizde hareketli ortalamalar, piyasanın genel trendini ve momentum değişimlerini anlamak için kullanılan en temel araçlardan biridir.<br />
<strong>Borsapin EMA Sinyal Tablosu,</strong> Fibonacci sayı dizisine dayalı EMA (Üstel Hareketli Ortalama) sistemini kullanarak yatırımcılara üç farklı zaman diliminde (kısa, orta, uzun vade) sinyal üreten gelişmiş bir indikatördür.</p>
<p>Fibonacci EMA Serileri<br />
<strong>Kısa Vade EMA&#8217;lar: 5, 8, 13, 21</strong></p>
<p>En hızlı tepki veren ortalamalar, Günlük işlemler için ideal , Kısa vadeli trend değişimlerini yakalar</p>
<p><strong>Orta Vade EMA&#8217;lar: 34, 55</strong></p>
<p>Orta vadeli trendin yönünü belirler, Haftalık strateji geliştiriciler için uygun, Gürültüyü filtreler, daha güvenilir sinyaller üretir</p>
<p><strong>Uzun Vade EMA&#8217;lar: 89, 144</strong></p>
<p>Ana trendin yönünü gösterir, Uzun vadeli yatırım kararları için kritik, En az yanıltıcı sinyaller üretir</p>
<p><strong>Kısa Vade Sinyal Sistemi Mantığı</strong></p>
<p>AL Sinyali Başlangıcı: Fiyat tüm EMA&#8217;ların (5,8,13,21) üzerinde ve EMA&#8217;ların eğimi yukarı yönlü<br />
Sinyal Devamı: EMA 21&#8217;in altına geçici sarkmalarda bile, EMA eğimi yukarı yönlü kaldığı sürece <strong>AL</strong> sinyali bozulmaz<br />
SAT Sinyali: Fiyat EMA 21&#8217;in altında ve EMA eğimi aşağı yönlü ise</p>
<p><strong>Orta ve Uzun Vade Sistemlerin Mantığı</strong></p>
<p>AL Sinyali: Fiyat ilgili EMA&#8217;ların üzerinde<br />
SAT Sinyali: Fiyat kritik EMA seviyesinin altında (55 ve 89)</p>
<p>Aynı anda üç farklı perspektiften piyasayı değerlendirebilirsiniz. Kısa vadeli gürültüyü uzun vadeli trendden ayırabilirsiniz. Sinyal çakışmalarında güçlü fırsatları belirleyebilirsiniz.</p>
<p>Bar sayacı ile sinyalin ne kadar süredir aktif olduğunu görebilir, Güç göstergesi (<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />) ile sinyalin kalitesini değerlendirme yapabilirsiniz,</p>
<p><strong>Avantajları </strong><br />
Farklı zaman dilimlerinde çelişkili sinyallerde temkinli olmanızı sağlar. Kısa vade sinyaller ile  giriş/çıkış noktalarını,  Orta-uzun vade sinyalleri ile ana trend yönünün teyidi, Sinyal tarihlerini takip ederek performans analizi yapabilirsiniz. Farklı hisseler için aynı kriterlerde karşılaştırma yapabilir, ayrıca sektörel rotasyonda hangi hisselerin güçlü olduğunu belirleme şansına sahip olabilirsiniz. Varlıklara sistematik yaklaşıp, duygusal karar almanızı engeller. Size Objektif sinyal üretimlerini gösterir.<br />
<a href="https://www.kursatsenturk.com/wp-content/uploads/2025/08/THYAO_2025-08-11_14-46-02_5f1e8.png"><img loading="lazy" decoding="async" class="aligncenter size-large wp-image-11503" src="https://www.kursatsenturk.com/wp-content/uploads/2025/08/THYAO_2025-08-11_14-46-02_5f1e8-1030x533.png" alt="" width="570" height="295" srcset="https://www.kursatsenturk.com/wp-content/uploads/2025/08/THYAO_2025-08-11_14-46-02_5f1e8-1030x533.png 1030w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/THYAO_2025-08-11_14-46-02_5f1e8-300x155.png 300w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/THYAO_2025-08-11_14-46-02_5f1e8-768x397.png 768w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/THYAO_2025-08-11_14-46-02_5f1e8-1536x795.png 1536w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/THYAO_2025-08-11_14-46-02_5f1e8-850x440.png 850w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/THYAO_2025-08-11_14-46-02_5f1e8-679x351.png 679w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/THYAO_2025-08-11_14-46-02_5f1e8-262x136.png 262w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/THYAO_2025-08-11_14-46-02_5f1e8-574x297.png 574w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/THYAO_2025-08-11_14-46-02_5f1e8.png 1815w" sizes="auto, (max-width: 570px) 100vw, 570px" /></a></p>
<p><strong>Dezavantajları ve Riskleri</strong><br />
EMA&#8217;lar geçmiş verilerle hesaplandığı için sinyaller gecikmeli gelir, Hızlı piyasa hareketlerinde geç kalabilir. Trend dönüş noktalarında yanıltıcı sinyaller verebilir. Yatay seyreden piyasalarda çok fazla sinyal üretebilir. Whipsaw (sahte sinyal) riski yüksek. Kısa vadede sık giriş-çıkış maliyetleri artabilir. Piyasa sadece teknik faktörlerden etkilenmez. Haberlere, makro ekonomik değişimlere tepki verebilir. Hacim, volatilite gibi faktörleri  indikatör hesaplamıyor. Geçmiş verilerle mükemmel çalışan parametreler gelecekte başarısız olabilir. Mesala Fibonacci sayıları her piyasa için optimal olmayabilir. Farklı volatilite ortamlarında farklı sonuçlar verebilir</p>
<blockquote><p><strong>Uyarılar </strong></p>
<p>Diğer teknik indikatörlerle teyit edin. Hacim analizini ihmal etmeyin, Para Giriş çıkışlarını kontrol edin, Temel analiz ile destekleyin. Yüksek Volatilite Dönemlerinde Özellikle dikkat etmeniz önerilir.  <strong>Borsapin EMA Sinyal Tablosu</strong>, Fibonacci sayı dizisinin doğal uyumunu teknik analize taşıyan, çoklu zaman diliminde objektif sinyaller üreten güçlü bir araçtır. Doğru kullanıldığında yatırımcılara önemli avantajlar sağlarken, limitasyonlarının da farkında olunması gerekmektedir. En önemlisi, hiçbir teknik indikatör tek başına %100 başarılı değildir. Bu sistemi, kapsamlı bir analiz sürecinin bir parçası olarak kullanmak, risk yönetimi kurallarıyla desteklemek ve sürekli performansını takip etmek başarılı sonuçlar için kritik öneme sahiptir. Geçmiş performans gelecekteki sonuçları garanti etmez. Her yatırım kararında kendi risk toleransınızı göz önünde bulundurun ve gerektiğinde profesyonel destek alın.</p></blockquote>
<p>Trading View Pine Script Kodu</p>
<pre class="EnlighterJSRAW" data-enlighter-language="generic">// Bu, Pine Script<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2122.png" alt="™" class="wp-smiley" style="height: 1em; max-height: 1em;" /> kodu Mozilla Kamu Lisansı 2.0 (MPL-2.0) altında lisanslandı
// © krstsntrk © BorsaPin codeispriority
//@version=6

indicator("BorsaPin Ema Sinyal Tablosu", overlay=true)

// Borsapin Ema Sinyal Tablosu
// Kısa Vade Fibonacci EMA'ları (5, 8, 13, 21)
ema5  = input.int(5, "EMA 5", minval=1, group="Kısa Vade")
ema8  = input.int(8, "EMA 8", minval=1, group="Kısa Vade")
ema13 = input.int(13, "EMA 13", minval=1, group="Kısa Vade")
ema21a = input.int(21, "EMA 21", minval=1, group="Kısa Vade")

// Orta Vade Fibonacci EMA'ları (34, 55)
ema34  = input.int(34, "EMA 34", minval=1, group="Orta Vade")
ema55a = input.int(55, "EMA 55", minval=1, group="Orta Vade")

// Uzun Vade Fibonacci EMA'ları (89, 144)
ema89  = input.int(89, "EMA 89", minval=1, group="Uzun Vade")
ema144 = input.int(144, "EMA 144", minval=1, group="Uzun Vade")

// Görsel ayarlar
showTable = input.bool(true, "Tabloyu Göster")
tablePos = input.string("Sağ Üst", "Tablo Konumu", options=["Sol Üst", "Sağ Üst", "Sol Alt", "Sağ Alt"])
showEMAs = input.bool(true, "EMA Çizgilerini Göster", group="Görsel")
onlyDaily = input.bool(false, "Sadece Günlük Verileri Göster", group="Görsel")

// Günlük Zaman Dilimi Verileri 
[dailyClose, dailyFib5, dailyFib8, dailyFib13, dailyFib21a, dailyFib34, dailyFib55a, dailyFib89, dailyFib144] =  request.security(syminfo.tickerid, "1D", [close, ta.ema(close, ema5), ta.ema(close, ema8), ta.ema(close, ema13), ta.ema(close, ema21a),  ta.ema(close, ema34), ta.ema(close, ema55a), ta.ema(close, ema89), ta.ema(close, ema144)])

// Günlük veriler için sinyal hesaplamaları
dailyEgimYukari = dailyFib5 &gt; dailyFib5[1] and dailyFib8 &gt; dailyFib8[1] and dailyFib13 &gt; dailyFib13[1] and dailyFib21a &gt; dailyFib21a[1]
dailyEgimAsagi = dailyFib21a &lt; dailyFib21a[1] and dailyFib13 &lt; dailyFib13[1]

// Günlük sinyaller
dailySinyalKisaAL = dailyClose &gt; dailyFib5 and dailyClose &gt; dailyFib8 and dailyClose &gt; dailyFib13 and dailyClose &gt; dailyFib21a and dailyEgimYukari
dailySinyalKisaSAT = dailyClose &lt; dailyFib21a and dailyEgimAsagi
dailySinyalOrtaAL = dailyClose &gt; dailyFib34 and dailyClose &gt; dailyFib55a
dailySinyalOrtaSAT = dailyClose &lt; dailyFib55a
dailySinyalUzunAL = dailyClose &gt; dailyFib89 and dailyClose &gt; dailyFib144
dailySinyalUzunSAT = dailyClose &lt; dailyFib144
// Fibonacci EMA Hesapları
fib5   = ta.ema(close, ema5)
fib8   = ta.ema(close, ema8)
fib13  = ta.ema(close, ema13)
fib21a = ta.ema(close, ema21a)

fib34  = ta.ema(close, ema34)
fib55a = ta.ema(close, ema55a)

fib89  = ta.ema(close, ema89)
fib144 = ta.ema(close, ema144)

// Günlük sinyal durumları
var string dailyKisaSinyalDurumu = "BEKLİYOR"
var string dailyOrtaSinyalDurumu = "BEKLİYOR"
var string dailyUzunSinyalDurumu = "BEKLİYOR"

var int dailyKisaBarSayaci = 0
var int dailyOrtaBarSayaci = 0
var int dailyUzunBarSayaci = 0

var string dailyTarihKisa = "Yok"
var string dailyTarihOrta = "Yok"
var string dailyTarihUzun = "Yok"

// Günlük sinyal mantıkları
if dailySinyalKisaAL and dailyKisaSinyalDurumu[1] != "AL"
    dailyKisaSinyalDurumu := "AL"
    dailyKisaBarSayaci := 1
    dailyTarihKisa := str.format("{0,date,dd.MM.yyyy}", time)
else if dailyKisaSinyalDurumu[1] == "AL" and dailyClose &gt; dailyFib21a and dailyEgimYukari
    dailyKisaSinyalDurumu := "AL"
    dailyKisaBarSayaci += 1
else if dailySinyalKisaSAT
    dailyKisaSinyalDurumu := "SAT"
    if dailyKisaSinyalDurumu[1] != "SAT"
        dailyKisaBarSayaci := 1
        dailyTarihKisa := str.format("{0,date,dd.MM.yyyy}", time)
    else
        dailyKisaBarSayaci += 1
else
    if dailyKisaSinyalDurumu[1] == "AL"
        dailyKisaSinyalDurumu := "AL"
        dailyKisaBarSayaci += 1
    else
        dailyKisaSinyalDurumu := "BEKLİYOR"
        dailyKisaBarSayaci := 0

if dailySinyalOrtaAL
    dailyOrtaSinyalDurumu := "AL"
    if dailyOrtaSinyalDurumu[1] != "AL"
        dailyOrtaBarSayaci := 1
        dailyTarihOrta := str.format("{0,date,dd.MM.yyyy}", time)
    else
        dailyOrtaBarSayaci += 1
else if dailySinyalOrtaSAT
    dailyOrtaSinyalDurumu := "SAT"
    if dailyOrtaSinyalDurumu[1] != "SAT"
        dailyOrtaBarSayaci := 1
        dailyTarihOrta := str.format("{0,date,dd.MM.yyyy}", time)
    else
        dailyOrtaBarSayaci += 1
else
    dailyOrtaSinyalDurumu := "BEKLİYOR"
    dailyOrtaBarSayaci := 0

if dailySinyalUzunAL
    dailyUzunSinyalDurumu := "AL"
    if dailyUzunSinyalDurumu[1] != "AL"
        dailyUzunBarSayaci := 1
        dailyTarihUzun := str.format("{0,date,dd.MM.yyyy}", time)
    else
        dailyUzunBarSayaci += 1
else if dailySinyalUzunSAT
    dailyUzunSinyalDurumu := "SAT"
    if dailyUzunSinyalDurumu[1] != "SAT"
        dailyUzunBarSayaci := 1
        dailyTarihUzun := str.format("{0,date,dd.MM.yyyy}", time)
    else
        dailyUzunBarSayaci += 1
else
    dailyUzunSinyalDurumu := "BEKLİYOR"
    dailyUzunBarSayaci := 0

// EMA Çizgileri
plot(showEMAs ? fib5 : na, "EMA 5", color=color.new(color.maroon, 50), linewidth=1)
plot(showEMAs ? fib8 : na, "EMA 8", color=color.new(color.blue, 50), linewidth=1)
plot(showEMAs ? fib13 : na, "EMA 13", color=color.new(color.green, 50), linewidth=1)
plot(showEMAs ? fib21a : na, "EMA 21", color=color.new(color.orange, 30), linewidth=1)
plot(showEMAs ? fib34 : na, "EMA 34", color=color.new(color.purple, 30), linewidth=1)
plot(showEMAs ? fib55a : na, "EMA 55", color=color.new(color.red, 20), linewidth=2)
plot(showEMAs ? fib89 : na, "EMA 89", color=color.new(color.fuchsia, 40), linewidth=2)
plot(showEMAs ? fib144 : na, "EMA 144", color=color.new(color.aqua, 40), linewidth=2)

// KISA VADE Sinyalleri  Detaylı Sinyal Mantığı  Her Vade İçin Ayrı 
// Eğim kontrolü
kisaVadeEgimYukari = fib5 &gt; fib5[1] and fib8 &gt; fib8[1] and fib13 &gt; fib13[1] and fib21a &gt; fib21a[1]

// AL sinyali: Tüm EMA'ların üzerinde ve eğim yukarı
sinyalKisaAL = close &gt; fib5 and close &gt; fib8 and close &gt; fib13 and close &gt; fib21a and kisaVadeEgimYukari

// SAT sinyali: EMA 21'in altına düşmesi ve eğim aşağı
kisaVadeEgimAsagi = fib21a &lt; fib21a[1] and fib13 &lt; fib13[1]
sinyalKisaSAT = close &lt; fib21a and kisaVadeEgimAsagi

// ORTA VADE Sinyalleri (Kısa vade mantığı uygulandı)
sinyalOrtaAL = close &gt; fib34 and close &gt; fib55a and fib34 &gt; fib55a

sinyalOrtaSAT = close &lt; fib55a

// UZUN VADE Sinyalleri (Sadece fiyat kontrolü)
sinyalUzunAL = close &gt; fib89 and close &gt; fib144

sinyalUzunSAT = close &lt; fib144

// Sinyal Durumu Değişkenleri 
var string kisaSinyalDurumu = "BEKLİYOR"
var string ortaSinyalDurumu = "BEKLİYOR"
var string uzunSinyalDurumu = "BEKLİYOR"

var int kisaBarSayaci = 0
var int ortaBarSayaci = 0
var int uzunBarSayaci = 0

var string tarihKisa = "Yok"
var string tarihOrta = "Yok"
var string tarihUzun = "Yok"

//  KISA VADE Sinyal Mantığı - Sürekli AL Mantığı
if sinyalKisaAL and kisaSinyalDurumu[1] != "AL"
    // İlk AL sinyali - tarih ve bar sayacı sıfırla
    kisaSinyalDurumu := "AL"
    kisaBarSayaci := 1
    tarihKisa := str.format("{0,date,dd.MM.yyyy}", time)
else if kisaSinyalDurumu[1] == "AL" and close &gt; fib21a and kisaVadeEgimYukari
    // AL sinyali devam ediyor - EMA 21 üzerinde ve eğim yukarı
    kisaSinyalDurumu := "AL"
    kisaBarSayaci += 1
else if sinyalKisaSAT
    // SAT sinyali
    kisaSinyalDurumu := "SAT"
    if kisaSinyalDurumu[1] != "SAT"
        kisaBarSayaci := 1
        tarihKisa := str.format("{0,date,dd.MM.yyyy}", time)
    else
        kisaBarSayaci += 1
else
    // Belirsizlik durumu
    if kisaSinyalDurumu[1] == "AL"
        kisaSinyalDurumu := "AL"
        kisaBarSayaci += 1
    else
        kisaSinyalDurumu := "BEKLİYOR"
        kisaBarSayaci := 0

//  ORTA VADE Sinyal Mantığı
if sinyalOrtaAL
    ortaSinyalDurumu := "AL"
    if ortaSinyalDurumu[1] != "AL"
        ortaBarSayaci := 0
        tarihOrta := str.format("{0,date,dd.MM.yyyy} ", time)
    else
        ortaBarSayaci += 1
else if sinyalOrtaSAT
    ortaSinyalDurumu := "SAT"
    if ortaSinyalDurumu[1] != "SAT"
        ortaBarSayaci := 0
        tarihOrta := str.format("{0,date,dd.MM.yyyy} ", time)
    else
        ortaBarSayaci += 1
else
    ortaSinyalDurumu := "BEKLİYOR"
    ortaBarSayaci := 0

// UZUN VADE Sinyal Mantığı 
if sinyalUzunAL
    uzunSinyalDurumu := "AL"
    if uzunSinyalDurumu[1] != "AL"
        uzunBarSayaci := 0
        tarihUzun := str.format("{0,date,dd.MM.yyyy} ", time)
    else
        uzunBarSayaci += 1
else if sinyalUzunSAT
    uzunSinyalDurumu := "SAT"
    if uzunSinyalDurumu[1] != "SAT"
        uzunBarSayaci := 0
        tarihUzun := str.format("{0,date,dd.MM.yyyy}", time)
    else
        uzunBarSayaci += 1
else
    uzunSinyalDurumu := "BEKLİYOR"
    uzunBarSayaci := 0

// Tablo konumu belirleme
tablePosition = if tablePos == "Sol Üst"
    position.top_left
else if tablePos == "Sağ Üst"
    position.top_right
else if tablePos == "Sol Alt"
    position.bottom_left
else if tablePos == "Sağ Alt"
    position.bottom_right
else
    position.top_right

// Tablo Oluşturma 
if showTable
    var table tablo = table.new(tablePosition, 5, 4, border_width=1, bgcolor=color.white, border_color=color.gray)

    // Başlık satırı
    table.cell(tablo, 0, 0, "Vade", bgcolor=color.new(color.blue, 80), text_color=color.black, text_size=size.small)
    table.cell(tablo, 1, 0, "Sinyal Tarihi", bgcolor=color.new(color.blue, 80), text_color=color.black, text_size=size.small)
    table.cell(tablo, 2, 0, "Bar", bgcolor=color.new(color.blue, 80), text_color=color.black, text_size=size.small)
    table.cell(tablo, 3, 0, "Durum", bgcolor=color.new(color.blue, 80), text_color=color.black, text_size=size.small)
    table.cell(tablo, 4, 0, "Güç", bgcolor=color.new(color.blue, 80), text_color=color.black, text_size=size.small)

    //  KISA VADE SATIRI 
    // Hangi veriler kullanılacak
    useKisaSinyalDurumu = onlyDaily ? dailyKisaSinyalDurumu : kisaSinyalDurumu
    useKisaBarSayaci = onlyDaily ? dailyKisaBarSayaci : kisaBarSayaci
    useTarihKisa = onlyDaily ? dailyTarihKisa : tarihKisa
    useKisaClose = onlyDaily ? dailyClose : close
    useKisaFib5 = onlyDaily ? dailyFib5 : fib5
    useKisaFib8 = onlyDaily ? dailyFib8 : fib8
    
    kisaRenk = if useKisaSinyalDurumu == "AL"
        if useKisaClose &lt; useKisaFib8 and useKisaClose &gt; useKisaFib5
            color.new(color.green, 40) // Orta Güçlü AL
        else if useKisaClose &lt; useKisaFib5
            color.new(color.green, 60) // Zayıf AL
        else
            color.new(color.green, 20) // Güçlü AL
    else if useKisaSinyalDurumu == "SAT"
        color.new(color.red, 20)
    else
        color.new(color.gray, 40)
    
    kisaDurumText = if useKisaSinyalDurumu == "AL" and useKisaClose &lt; useKisaFib8
        "AL (Zayıf)"
    else if useKisaSinyalDurumu == "AL" and useKisaClose &gt; useKisaFib8
        "AL (Güçlü)"
    else
        useKisaSinyalDurumu

    kisaGuc = if useKisaSinyalDurumu == "AL" 
        if useKisaBarSayaci &lt;= 5
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />"
        else if useKisaBarSayaci &lt;= 15
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />"
        else if useKisaBarSayaci &lt;= 30
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />"
        else
            ""
    else if useKisaSinyalDurumu == "SAT"
        if useKisaBarSayaci &lt;= 5
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />"
        else if useKisaBarSayaci &lt;= 15
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />"
        else if useKisaBarSayaci &lt;= 30
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />"
        else
            ""
    else
        "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/23f3.png" alt="⏳" class="wp-smiley" style="height: 1em; max-height: 1em;" />"

    kisaBarText = useKisaSinyalDurumu == "BEKLİYOR" ? "" : str.tostring(useKisaBarSayaci)

    table.cell(tablo, 0, 1, "Kısa Vade", text_size=size.small)
    table.cell(tablo, 1, 1, useTarihKisa, text_size=size.tiny)
    table.cell(tablo, 2, 1, kisaBarText, text_size=size.small)
    table.cell(tablo, 3, 1, kisaDurumText, bgcolor=kisaRenk, text_color=color.white, text_size=size.small)
    table.cell(tablo, 4, 1, kisaGuc, text_size=size.small)

    // ORTA VADE SATIRI 
    ortaRenk = if ortaSinyalDurumu == "AL"
        if close &lt; fib34 and close &gt; fib55a
            color.new(color.green, 60) // Zayıf AL
        else if close &gt; fib34
            color.new(color.green, 20) // Güçlü AL
        else
            color.new(color.green, 40) // Orta AL
    else if ortaSinyalDurumu == "SAT"
        color.new(color.red, 20)
    else
        color.new(color.gray, 40)
        
    ortaDurumText = if ortaSinyalDurumu == "AL" and close &lt; fib34
        "AL (Zayıf)"
    else if ortaSinyalDurumu == "AL" and close &gt; fib34
        "AL (Güçlü)"
    else
        ortaSinyalDurumu
        
    ortaGuc = if ortaSinyalDurumu == "AL" 
        if ortaBarSayaci &lt;= 5 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else if ortaBarSayaci &lt;= 15 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else if ortaBarSayaci &lt;= 30 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else 
            ""
    else if ortaSinyalDurumu == "SAT" 
        if ortaBarSayaci &lt;= 5 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else if ortaBarSayaci &lt;= 15 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else if ortaBarSayaci &lt;= 30 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else 
            ""
    else 
        "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/23f3.png" alt="⏳" class="wp-smiley" style="height: 1em; max-height: 1em;" />"
        
    ortaBarText = ortaSinyalDurumu == "BEKLİYOR" ? "" : str.tostring(ortaBarSayaci)

    table.cell(tablo, 0, 2, "Orta Vade", text_size=size.small)
    table.cell(tablo, 1, 2, tarihOrta, text_size=size.tiny)
    table.cell(tablo, 2, 2, ortaBarText, text_size=size.small)
    table.cell(tablo, 3, 2, ortaDurumText, bgcolor=ortaRenk, text_color=color.white, text_size=size.small)
    table.cell(tablo, 4, 2, ortaGuc, text_size=size.small)

    //  UZUN VADE SATIRI 
    uzunRenk = if uzunSinyalDurumu == "AL"
        if close &lt; fib89 and close &gt; fib144
            color.new(color.green, 60) // Zayıf AL
        else if close &gt; fib89
            color.new(color.green, 20) // Güçlü AL
        else
            color.new(color.green, 40) // Orta AL
    else if uzunSinyalDurumu == "SAT"
        color.new(color.red, 20)
    else
        color.new(color.gray, 40)
        
    uzunDurumText = if uzunSinyalDurumu == "AL" and close &lt; fib89
        "AL (Zayıf)"
    else if uzunSinyalDurumu == "AL" and close &gt; fib89
        "AL (Güçlü)"
    else
        uzunSinyalDurumu
        
    uzunGuc = if uzunSinyalDurumu == "AL" 
        if uzunBarSayaci &lt;= 5 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else if uzunBarSayaci &lt;= 15 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else if uzunBarSayaci &lt;= 30 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else if uzunBarSayaci &lt;= 50 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else 
            ""
    else if uzunSinyalDurumu == "SAT" 
        if uzunBarSayaci &lt;= 5 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else if uzunBarSayaci &lt;= 15 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else if uzunBarSayaci &lt;= 30 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /><img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else if uzunBarSayaci &lt;= 50 
            "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" />" 
        else 
            ""
    else 
        "<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/23f3.png" alt="⏳" class="wp-smiley" style="height: 1em; max-height: 1em;" />"
        
    uzunBarText = uzunSinyalDurumu == "BEKLİYOR" ? "" : str.tostring(uzunBarSayaci)

    table.cell(tablo, 0, 3, "Uzun Vade", text_size=size.small)
    table.cell(tablo, 1, 3, tarihUzun, text_size=size.tiny)
    table.cell(tablo, 2, 3, uzunBarText, text_size=size.small)
    table.cell(tablo, 3, 3, uzunDurumText, bgcolor=uzunRenk, text_color=color.white, text_size=size.small)
    table.cell(tablo, 4, 3, uzunGuc, text_size=size.small)</pre>
<p>&nbsp;</p><p>The post <a href="https://www.kursatsenturk.com/2025/08/borsapin-ema-sinyal-tablosu-kisa-orta-uzun-vade.html">Borsapin EMA Sinyal Tablosu (Kısa, Orta, Uzun Vade)</a> first appeared on <a href="https://www.kursatsenturk.com">SDC</a>.</p>]]></content:encoded>
					
					<wfw:commentRss>https://www.kursatsenturk.com/2025/08/borsapin-ema-sinyal-tablosu-kisa-orta-uzun-vade.html/feed</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
		<item>
		<title>Python BorsaPin Lineer Regresyon ve Pearson Analizi Betiği</title>
		<link>https://www.kursatsenturk.com/2025/08/python-borsapin-lineer-regresyon-ve-pearson-analizi-betigi.html</link>
					<comments>https://www.kursatsenturk.com/2025/08/python-borsapin-lineer-regresyon-ve-pearson-analizi-betigi.html#respond</comments>
		
		<dc:creator><![CDATA[sdc]]></dc:creator>
		<pubDate>Wed, 06 Aug 2025 13:33:18 +0000</pubDate>
				<category><![CDATA[BorsaPin]]></category>
		<category><![CDATA[Python]]></category>
		<category><![CDATA[Teknik Analiz]]></category>
		<category><![CDATA[borsa analizi]]></category>
		<category><![CDATA[borsa stratejileri]]></category>
		<category><![CDATA[borsa verisi analizi]]></category>
		<category><![CDATA[breakout sinyalleri]]></category>
		<category><![CDATA[EMA dizilimi]]></category>
		<category><![CDATA[Excel dosyası]]></category>
		<category><![CDATA[Excel raporu]]></category>
		<category><![CDATA[Excel veri işleme]]></category>
		<category><![CDATA[finansal analiz]]></category>
		<category><![CDATA[finansal analiz araçları]]></category>
		<category><![CDATA[finansal korelasyon]]></category>
		<category><![CDATA[finansal raporlama.]]></category>
		<category><![CDATA[finansal veri analizi]]></category>
		<category><![CDATA[finansal veri görselleştirme]]></category>
		<category><![CDATA[fırsat analizi]]></category>
		<category><![CDATA[hisse senedi analizi]]></category>
		<category><![CDATA[hisse senedi trendleri]]></category>
		<category><![CDATA[istatistiksel analiz]]></category>
		<category><![CDATA[kanal fırsatları]]></category>
		<category><![CDATA[lineer regresyon analizi]]></category>
		<category><![CDATA[Pearson korelasyonu]]></category>
		<category><![CDATA[Python betiği]]></category>
		<category><![CDATA[Python ile yatırım analizi]]></category>
		<category><![CDATA[regresyon analizi Python]]></category>
		<category><![CDATA[veri analizi]]></category>
		<category><![CDATA[yatırım analiz araçları]]></category>
		<category><![CDATA[yatırım fırsatları]]></category>
		<category><![CDATA[yatırım fırsatları tespiti]]></category>
		<category><![CDATA[yatırım kararları]]></category>
		<category><![CDATA[yatırımcılar için araçlar]]></category>
		<guid isPermaLink="false">https://www.kursatsenturk.com/?p=11446</guid>

					<description><![CDATA[<p>Bu Python betiği, X_01_BorsaPin_StokData.py  Python betiğiyle oluşturulan StokData/Kapanis klasöründeki hisse kapanış verilerinden lineer regresyon trend analizi ve Pearson korelasyon ölçümleri yaparak detaylı teknik analiz raporu üretir. Analizler, Excel formatında renklendirilmiş ve filtrelenebilir şekilde kayıt altına alınır. Terminalden şu iki komutu çalıştırın . python.exe -m pip install --upgrade pip pip install pandas numpy scipy colorama openpyxl [&#8230;]</p>
<p>The post <a href="https://www.kursatsenturk.com/2025/08/python-borsapin-lineer-regresyon-ve-pearson-analizi-betigi.html">Python BorsaPin Lineer Regresyon ve Pearson Analizi Betiği</a> first appeared on <a href="https://www.kursatsenturk.com">SDC</a>.</p>]]></description>
										<content:encoded><![CDATA[<p><a href="https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython.png"><img loading="lazy" decoding="async" class="aligncenter size-full wp-image-11510" src="https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython.png" alt="" width="777" height="548" srcset="https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython.png 777w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython-300x212.png 300w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython-768x542.png 768w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython-679x479.png 679w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython-262x185.png 262w, https://www.kursatsenturk.com/wp-content/uploads/2025/08/Borsapinpython-574x405.png 574w" sizes="auto, (max-width: 777px) 100vw, 777px" /></a></p>
<p>Bu Python betiği, X_01_BorsaPin_StokData.py  Python betiğiyle oluşturulan StokData/Kapanis klasöründeki hisse kapanış verilerinden lineer regresyon trend analizi ve Pearson korelasyon ölçümleri yaparak detaylı teknik analiz raporu üretir. Analizler, Excel formatında renklendirilmiş ve filtrelenebilir şekilde kayıt altına alınır.</p>
<p>Terminalden şu iki komutu çalıştırın .<br />
<code>python.exe -m pip install --upgrade pip<br />
pip install pandas numpy scipy colorama openpyxl</code></p>
<h5>Kodun Temel Özellikleri</h5>
<p>Lineer Regresyon Analizi: Kapanış fiyatları üzerinden trend çizgisi (slope), kanal bandı, standart sapma gibi metrikleri hesaplar.<br />
<span style="font-size: 14px;">Pearson Korelasyon: Trendin gücünü ölçmek için farklı periyotlarda Pearson korelasyon katsayısı hesaplanır.</span></p>
<p>&nbsp;</p>
<h5><strong>Fırsat Tespiti:</strong></h5>
<p><strong>Kanal Altı Fırsatları: Alt banda yakın fiyat hareketleri ve güçlü korelasyon içeren hisseler.</strong></p>
<p><strong>Breakout Adayları: Üst banda yakın olup yükseliş sinyali veren hisseler.</strong></p>
<p><strong>EMA Dizilim Entegrasyonu:</strong> Farklı script tarafından oluşturulan EMA analizleriyle birleştirilebilir.</p>
<p><strong>Otomatik Excel Raporu:</strong> Tüm veriler biçimlendirilmiş bir Excel dosyasına kaydedilir (filtrelenebilir, renklendirilmiş).</p>
<p><strong>Başarısız Dosya Takibi:</strong> Hatalı veriler ayrı bir .txt dosyasına kaydedilir. Analiz Süreci Otomatik Gerçekleşir:</p>
<p>Tüm dosyalar sırasıyla işlenir. Lineer regresyon analizleri yapılır. Fırsatlar belirlenir. Sonuçlar Excel ve TXT dosyalarına kaydedilir.</p>
<h6>Üretilen Dosyalar</h6>
<p><strong>StokData/lineer_regresyon_analiz.xlsx → Ana analiz dosyası</strong><br />
<strong>StokData/LinearRegression/lineer_regresyon_analiz_YYYY-MM-DD.xlsx → Arşiv dosyası</strong></p>
<p>basarisiz_regresyon_dosyalari.txt → Başarısız analizlerin listesi</p>
<p><em><strong>Excel Sayfaları</strong></em><br />
TumSonuclar: Tüm hisse ve periyot sonuçları<br />
<span style="font-size: 14px;">IdealPearson: En güçlü Pearson korelasyonuna sahip hisseler<br />
</span><span style="font-size: 14px;">KanalFirsatlari_Top50: Kanal altına yakın fırsatlar<br />
</span><span style="font-size: 14px;">BreakoutAdaylari_Top50: Yükselişe aday hisseler<br />
</span><span style="font-size: 14px;">Periyot_XXX: Her analiz periyodu için ayrı sayfalar<br />
</span><span style="font-size: 14px;">Istatistikler: Genel başarı ve analiz özetleri</span></p>
<h5>Avantajları</h5>
<p>Otomatik, hızlı ve güvenilir teknik analiz.  Yatırım kararlarını destekleyecek fırsat ve sinyal tespiti. Excel üzerinden kolay görsel analiz ve filtreleme imkânı</p>
<p>Bu betik, teknik analizde trend doğruluğunu ve fırsatları istatistiksel olarak belirlemek isteyen yatırımcılar için güçlü bir araçtır. Özellikle BIST verileriyle çalışan sistemlerde regresyon ve Pearson tabanlı analiz ile öne çıkan hisseleri kolayca tespit etmeye yardımcı olur.</p>
<p>LinReg tarama çalışmamızı <strong>X_05_BorsaPin_LinReg_Tarama.py</strong> adıyla kayıt edebilirsiniz.<br />
<strong>Python Betiği</strong></p>
<pre class="EnlighterJSRAW" data-enlighter-language="generic">import pandas as pd
import numpy as np
import os
import glob
from scipy.stats import linregress, pearsonr
from datetime import datetime, timedelta
from colorama import Fore, init
from openpyxl.styles import Font, PatternFill, Alignment
from openpyxl.utils import get_column_letter
from typing import List, Dict, Optional

"""
      Borsapin StokData/Kapanis klasöründeki hisse verilerinden Lineer Regresyon ve Pearson analizi yapar
      www.kursatsenturk.com

      """

init(autoreset=True)


class LinearRegressionAnalyzer:
    def __init__(self):
        self.pearson_periods = [55, 89, 144, 233, 370, 610, 987]
        self.analysis_periods = [55, 89, 144, 233, 370, 610, 987]  # Özel analiz periyotları
        self.successful_files = []
        self.failed_files = []

        # Sonuç listeleri
        self.all_results = []
        self.period_results = {period: [] for period in self.pearson_periods}
        self.ideal_pearson = []
        self.channel_opportunities = []
        self.breakout_candidates = []
        self.statistics = {}

    @staticmethod
    def calculate_regression(data_df: pd.DataFrame, period: int) -&gt; Optional[Dict]:
        """Lineer regresyon ve kanal hesaplama"""
        try:
            # Son 'period' a kadar veriyi al
            data_df = data_df.tail(period).copy()
            if len(data_df) &lt; period:
                return None

            # X ekseni (zaman) ve Y ekseni (fiyat) değerleri
            x = np.arange(len(data_df))
            y = data_df["Kapanış"].values

            # Lineer regresyon hesaplama
            slope, intercept, r_value, p_value, std_err = linregress(x, y)

            # Trend çizgisi hesaplama
            trend_line = intercept + slope * x

            # Residual (artık) değerler ve standart sapma
            residuals = y - trend_line
            std_dev = np.std(residuals)

            # Kanal bantları (2 standart sapma)
            upper_channel = trend_line + 2 * std_dev
            lower_channel = trend_line - 2 * std_dev

            # Pearson korelasyon katsayısı
            corr, _ = pearsonr(x, y)

            # Son değerler
            upper_channel_value = round(float(upper_channel[-1]), 2)
            lower_channel_value = round(float(lower_channel[-1]), 2)
            trend_value = round(float(trend_line[-1]), 2)
            last_price = float(y[-1])

            # Yüzde farkları
            upper_diff_pct = round((last_price - upper_channel_value) / last_price * 100, 2)
            lower_diff_pct = round((last_price - lower_channel_value) / last_price * 100, 2)
            trend_diff_pct = round((last_price - trend_value) / last_price * 100, 2)

            # Trend yönü ve güç
            trend_direction = "Yükseliş" if slope &gt; 0 else "Düşüş"
            trend_strength = "Güçlü" if abs(slope) &gt; 0.05 else "Orta" if abs(slope) &gt; 0.01 else "Zayıf"

            # Kanal pozisyonu
            channel_position = "Üst Bant" if upper_diff_pct &gt;= -2 else "Alt Bant" if lower_diff_pct &lt;= 2 else "Orta"

            return {
                "Periyot": period,
                "Kanal_Ust": upper_channel_value,
                "Kanal_Alt": lower_channel_value,
                "Trend_Cizgisi": trend_value,
                "Ust_Fark_Pct": upper_diff_pct,
                "Alt_Fark_Pct": lower_diff_pct,
                "Trend_Fark_Pct": trend_diff_pct,
                "Trend_Yonu": trend_direction,
                "Trend_Gucu": trend_strength,
                "Kanal_Pozisyonu": channel_position,
                "Pearson": round(corr, 4),
                "R_Kare": round(r_value ** 2, 4),
                "Slope": round(slope, 6),
                "P_Value": round(p_value, 6),
                "Std_Error": round(std_err, 6)
            }

        except Exception as e:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Regresyon hesaplama hatası (Period {period}): {e}")
            return None

    def process_single_file(self, file_path: str) -&gt; bool:
        """Tek dosya için lineer regresyon analizi"""
        ticker_name = None
        try:
            # Dosya adından hisse adını alma
            file_name = os.path.basename(file_path)
            ticker_name = os.path.splitext(file_name)[0]

            print(f"{Fore.YELLOW} Lineer regresyon analizi: {ticker_name}...")

            # Excel dosyasını okuma
            df = pd.read_excel(file_path)

            # Gerekli sütunların varlığını kontrol etme
            if 'Tarih' not in df.columns or 'Kapanış' not in df.columns:
                raise ValueError("Tarih veya Kapanış sütunu bulunamadı")

            # Veri temizleme ve sıralama
            df = df[["Tarih", "Kapanış"]].dropna()
            df["Tarih"] = pd.to_datetime(df["Tarih"])
            df = df.sort_values("Tarih").reset_index(drop=True)
            df["Kapanış"] = pd.to_numeric(df["Kapanış"], errors='coerce')
            df = df.dropna()

            if df.empty:
                raise ValueError("Veri boş veya geçersiz")

            last_close = round(float(df["Kapanış"].iloc[-1]), 2)
            last_date = df["Tarih"].iloc[-1]

            print(f"{Fore.CYAN}   <img src="https://s.w.org/images/core/emoji/17.0.2/72x72/26a1.png" alt="⚡" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Periyotlar hesaplanıyor: ", end="")

            # Her periyot için analiz
            ticker_pearson_data = {"Hisse_Adi": ticker_name, "Kapanış": last_close, "Tarih": last_date}

            for i, period in enumerate(self.pearson_periods):
                print(f"{period}", end="")

                result = self.calculate_regression(df.copy(), period)
                if result:
                    # Ana sonuç listesine ekle
                    main_result = {
                        "Hisse_Adi": ticker_name,
                        "Kapanış": last_close,
                        "Tarih": last_date,
                        **result
                    }
                    self.all_results.append(main_result)

                    # Periyot bazlı sonuçlara ekle
                    self.period_results[period].append(main_result)

                    # İdeal Pearson için veri toplama
                    ticker_pearson_data[f"Pearson_{period}"] = result["Pearson"]
                    ticker_pearson_data[f"Kanal_Pozisyon_{period}"] = result["Kanal_Pozisyonu"]
                    ticker_pearson_data[f"Alt_Fark_{period}"] = result["Alt_Fark_Pct"]
                    ticker_pearson_data[f"Ust_Fark_{period}"] = result["Ust_Fark_Pct"]

                if i &lt; len(self.pearson_periods) - 1:
                    print(", ", end="")
            print()

            # İdeal Pearson listesine ekle
            self.ideal_pearson.append(ticker_pearson_data)

            # Özel analizler için kontrol
            self.analyze_opportunities(ticker_name, last_close, last_date, df)

            print(f"{Fore.GREEN}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2705.png" alt="✅" class="wp-smiley" style="height: 1em; max-height: 1em;" /> {ticker_name} analizi tamamlandı.")
            self.successful_files.append(ticker_name)
            return True

        except Exception as e:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> {ticker_name if ticker_name else file_path} için hata: {e}")
            self.failed_files.append(os.path.basename(file_path))
            return False

    def analyze_opportunities(self, ticker_name: str, last_close: float, last_date, df: pd.DataFrame):
        """Fırsat analizi - kanal alt bandı ve breakout adayları"""
        try:
            for period in self.analysis_periods:
                result = self.calculate_regression(df.copy(), period)
                if result:
                    # Alt banda yakın fırsatlar (Alt fark &lt;= 4% ve Pearson &gt;= 0.7)
                    if (-2 &lt;= result["Alt_Fark_Pct"] &lt;= 4 and
                            abs(result["Pearson"]) &gt;= 0.7):
                        self.channel_opportunities.append({
                            "Hisse_Adi": ticker_name,
                            "Kapanış": last_close,
                            "Tarih": last_date,
                            "Periyot": period,
                            "Alt_Fark_Pct": result["Alt_Fark_Pct"],
                            "Pearson": result["Pearson"],
                            "Trend_Yonu": result["Trend_Yonu"],
                            "Kanal_Alt": result["Kanal_Alt"],
                            "Kanal_Ust": result["Kanal_Ust"],
                            "Potansiyel_Kazanc": round((result["Kanal_Ust"] - last_close) / last_close * 100, 2)
                        })

                    # Breakout adayları (Üst fark &gt;= -4% ve Pearson &gt;= 0.8)
                    if (-4 &lt;= result["Ust_Fark_Pct"] &lt;= 2 and
                            abs(result["Pearson"]) &gt;= 0.8):
                        self.breakout_candidates.append({
                            "Hisse_Adi": ticker_name,
                            "Kapanış": last_close,
                            "Tarih": last_date,
                            "Periyot": period,
                            "Ust_Fark_Pct": result["Ust_Fark_Pct"],
                            "Pearson": result["Pearson"],
                            "Trend_Yonu": result["Trend_Yonu"],
                            "Kanal_Ust": result["Kanal_Ust"],
                            "Hedef_Fiyat": round(result["Kanal_Ust"] * 1.05, 2)  # %5 üst hedef
                        })

        except Exception as e:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Fırsat analizi hatası ({ticker_name}): {e}")

    def calculate_statistics(self):
        """İstatistik hesaplama"""
        try:
            print(f"{Fore.CYAN} İstatistikler hesaplanıyor...")

            # Genel istatistikler
            stats = {
                "Toplam_Analiz_Edilen": len(self.successful_files),
                "Basarisiz_Dosya": len(self.failed_files)
            }

            # Periyot bazlı istatistikler
            for period in self.pearson_periods:
                period_data = self.period_results[period]
                if period_data:
                    pearson_values = [item["Pearson"] for item in period_data if item.get("Pearson")]
                    stats[f"Ortalama_Pearson_{period}"] = round(np.mean(pearson_values), 4) if pearson_values else 0
                    stats[f"Yuksek_Pearson_Sayisi_{period}"] = len([p for p in pearson_values if abs(p) &gt;= 0.8])

            # Fırsat istatistikleri
            stats["Kanal_Alt_Firsatlari"] = len(self.channel_opportunities)
            stats["Breakout_Adaylari"] = len(self.breakout_candidates)

            # Trend analizi
            trend_up = len([item for item in self.all_results if item.get("Trend_Yonu") == "Yükseliş"])
            trend_down = len([item for item in self.all_results if item.get("Trend_Yonu") == "Düşüş"])
            stats["Yukselis_Trendi"] = trend_up
            stats["Dusus_Trendi"] = trend_down

            self.statistics = stats
            return stats

        except Exception as e:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> İstatistik hesaplama hatası: {e}")
            return {}

    @staticmethod
    def find_input_files(input_folder="StokData/Kapanis/"):
        """Giriş dosyalarını bulma"""
        try:
            pattern = os.path.join(input_folder, "*.xlsx")
            files = glob.glob(pattern)

            if not files:
                print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> {input_folder} klasöründe Excel dosyası bulunamadı!")
                return []

            print(f"{Fore.BLUE} {len(files)} adet Excel dosyası bulundu.")
            return files

        except Exception as e:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Dosya arama hatası: {e}")
            return []

    def merge_ema_data(self):
        """EMA dizilim verilerini birleştirme"""
        try:
            ema_file = "StokData/idealema_analiz.xlsx"
            if os.path.exists(ema_file):
                print(f"{Fore.CYAN} EMA verileri birleştiriliyor...")
                ema_df = pd.read_excel(ema_file, sheet_name="IdealEMAUp")
                ema_mapping = dict(zip(ema_df["Hisse_Adi"], ema_df["EMA_Dizilim"]))

                # Tüm sonuçlara EMA bilgisi ekle
                for result in self.all_results:
                    result["EMA_Dizilim"] = ema_mapping.get(result["Hisse_Adi"], "Bilinmiyor")

                for result in self.ideal_pearson:
                    result["EMA_Dizilim"] = ema_mapping.get(result["Hisse_Adi"], "Bilinmiyor")

                print(f"{Fore.GREEN}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2705.png" alt="✅" class="wp-smiley" style="height: 1em; max-height: 1em;" /> EMA verileri başarıyla birleştirildi.")
            else:
                print(f"{Fore.YELLOW}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/26a0.png" alt="⚠" class="wp-smiley" style="height: 1em; max-height: 1em;" />  EMA dosyası bulunamadı: {ema_file}")

        except Exception as e:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> EMA veri birleştirme hatası: {e}")

    @staticmethod
    def write_sheet_with_formatting(excel_writer, df, sheet_name, freeze_panes=None):
        """Excel sayfası yazma ve biçimlendirme"""
        try:
            if isinstance(df, list):
                df = pd.DataFrame(df)

            if df.empty:
                df = pd.DataFrame([{"Mesaj": "Veri bulunamadı"}])

            df.to_excel(excel_writer, sheet_name=sheet_name, index=False)
            ws = excel_writer.sheets[sheet_name]

            # Başlık biçimlendirme
            header_fill = PatternFill(start_color='4472C4', end_color='4472C4', fill_type='solid')
            for col_num, column in enumerate(df.columns, 1):
                cell = ws.cell(row=1, column=col_num)
                cell.font = Font(bold=True, color='FFFFFF')
                cell.fill = header_fill
                cell.alignment = Alignment(horizontal='center')

                # Sütun genişlikleri
                if any(keyword in str(column) for keyword in ['Tarih', 'Date']):
                    ws.column_dimensions[get_column_letter(col_num)].width = 15
                elif any(keyword in str(column) for keyword in ['Hisse', 'CODE']):
                    ws.column_dimensions[get_column_letter(col_num)].width = 12
                elif any(keyword in str(column) for keyword in ['Pearson', 'Fark', 'Pct']):
                    ws.column_dimensions[get_column_letter(col_num)].width = 18
                else:
                    ws.column_dimensions[get_column_letter(col_num)].width = 20

            # Veri satırlarını biçimlendirme
            for row_num in range(2, len(df) + 2):
                for col_num in range(1, len(df.columns) + 1):
                    cell = ws.cell(row=row_num, column=col_num)
                    cell.alignment = Alignment(horizontal='center')
                    column_name = df.columns[col_num - 1]

                    # Pearson değerleri için renklendirme
                    if 'Pearson' in str(column_name) and isinstance(cell.value, (int, float)):
                        if abs(cell.value) &gt;= 0.9:
                            cell.fill = PatternFill(start_color='00FF00', end_color='00FF00', fill_type='solid')
                        elif abs(cell.value) &gt;= 0.8:
                            cell.fill = PatternFill(start_color='90EE90', end_color='90EE90', fill_type='solid')
                        elif abs(cell.value) &gt;= 0.7:
                            cell.fill = PatternFill(start_color='FFFF99', end_color='FFFF99', fill_type='solid')

                    # Fark yüzdeleri için renklendirme
                    elif 'Alt_Fark' in str(column_name) and isinstance(cell.value, (int, float)):
                        if -2 &lt;= cell.value &lt;= 4:
                            cell.fill = PatternFill(start_color='FFFFCC', end_color='FFFFCC', fill_type='solid')

                    elif 'Ust_Fark' in str(column_name) and isinstance(cell.value, (int, float)):
                        if -4 &lt;= cell.value &lt;= 2:
                            cell.fill = PatternFill(start_color='FFCCCC', end_color='FFCCCC', fill_type='solid')

            # Freeze panes
            if freeze_panes:
                ws.freeze_panes = freeze_panes

            # AutoFilter ekleme (başlık satırına)
            if len(df) &gt; 0:
                ws.auto_filter.ref = f"A1:{get_column_letter(len(df.columns))}{len(df) + 1}"

        except Exception as e:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Excel biçimlendirme hatası ({sheet_name}): {e}")

    def save_results(self):
        """Sonuçları Excel'e kaydetme"""
        try:
            # Klasörler oluşturma
            output_folder = "StokData/LinearRegression/"
            os.makedirs(output_folder, exist_ok=True)

            # Dosya isimleri
            today = datetime.today().strftime('%Y-%m-%d')
            main_file = os.path.join("StokData", "lineer_regresyon_analiz.xlsx")
            archive_file = os.path.join(output_folder, f"lineer_regresyon_analiz_{today}.xlsx")

            # Veri hazırlama
            print(f"{Fore.GREEN} Excel dosyası hazırlanıyor...")

            # Sıralama işlemleri
            # İdeal Pearson - maksimum mutlak Pearson değerine göre sırala
            ideal_pearson_df = pd.DataFrame(self.ideal_pearson)
            if not ideal_pearson_df.empty:
                pearson_cols = [col for col in ideal_pearson_df.columns if 'Pearson_' in col]
                if pearson_cols:
                    ideal_pearson_df['Max_Abs_Pearson'] = ideal_pearson_df[pearson_cols].abs().max(axis=1)
                    ideal_pearson_df = ideal_pearson_df.sort_values('Max_Abs_Pearson', ascending=False)

            # Kanal fırsatları - Pearson değerine göre sırala (İlk 50)
            channel_opp_df = pd.DataFrame(self.channel_opportunities)
            if not channel_opp_df.empty:
                channel_opp_df = channel_opp_df.sort_values(['Pearson', 'Alt_Fark_Pct'], ascending=[False, True]).head(
                    50)

            # Breakout adayları - Pearson değerine göre sırala (İlk 50)
            breakout_df = pd.DataFrame(self.breakout_candidates)
            if not breakout_df.empty:
                breakout_df = breakout_df.sort_values(['Pearson', 'Ust_Fark_Pct'], ascending=[False, False]).head(50)

            # İstatistikler
            stats_df = pd.DataFrame([
                {"Metrik": key, "Deger": value} for key, value in self.statistics.items()
            ])

            # Ana dosyayı kaydet
            print(f"{Fore.GREEN} Ana dosya kaydediliyor: {main_file}")
            with pd.ExcelWriter(main_file, engine='openpyxl') as writer:
                # Ana sayfalar
                self.write_sheet_with_formatting(writer, pd.DataFrame(self.all_results), "TumSonuclar", "A2")
                self.write_sheet_with_formatting(writer, ideal_pearson_df, "IdealPearson", "A2")
                self.write_sheet_with_formatting(writer, channel_opp_df, "KanalFirsatlari_Top50", "A2")
                self.write_sheet_with_formatting(writer, breakout_df, "BreakoutAdaylari_Top50", "A2")
                self.write_sheet_with_formatting(writer, stats_df, "Istatistikler", "A2")

                # Periyot bazlı sayfalar
                for period in self.pearson_periods:
                    period_df = pd.DataFrame(self.period_results[period])
                    if not period_df.empty:
                        period_df = period_df.sort_values('Pearson', ascending=False)
                        self.write_sheet_with_formatting(writer, period_df, f"Periyot_{period}", "A2")

            # Arşiv dosyasını kaydet
            print(f"{Fore.BLUE} Arşiv dosyası kaydediliyor: {archive_file}")
            with pd.ExcelWriter(archive_file, engine='openpyxl') as writer:
                self.write_sheet_with_formatting(writer, pd.DataFrame(self.all_results), "TumSonuclar", "A2")
                self.write_sheet_with_formatting(writer, ideal_pearson_df, "IdealPearson", "A2")
                self.write_sheet_with_formatting(writer, channel_opp_df, "KanalFirsatlari_Top50", "A2")
                self.write_sheet_with_formatting(writer, breakout_df, "BreakoutAdaylari_Top50", "A2")
                self.write_sheet_with_formatting(writer, stats_df, "Istatistikler", "A2")

                for period in self.pearson_periods:
                    period_df = pd.DataFrame(self.period_results[period])
                    if not period_df.empty:
                        period_df = period_df.sort_values('Pearson', ascending=False)
                        self.write_sheet_with_formatting(writer, period_df, f"Periyot_{period}", "A2")

            return True

        except Exception as e:
            print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Sonuç kaydetme hatası: {e}")
            return False

    def print_summary(self):
        """Özet rapor"""
        total = len(self.successful_files) + len(self.failed_files)
        success_rate = (len(self.successful_files) / total * 100) if total &gt; 0 else 0

        print(f"\n{Fore.CYAN} ===== LİNEER REGRESYON ANALİZ RAPORU =====")
        print(f"{Fore.BLUE} Analiz Periyotları: {', '.join(map(str, self.pearson_periods))}")
        print(f"{Fore.GREEN}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2705.png" alt="✅" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Başarılı: {len(self.successful_files)}")
        print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Başarısız: {len(self.failed_files)}")
        print(f"{Fore.BLUE} Başarı oranı: {success_rate:.1f}%")

        print(f"\n{Fore.MAGENTA} SONUÇLAR:")
        print(f"{Fore.GREEN}   Toplam Analiz: {len(self.all_results)}")
        print(f"{Fore.YELLOW}   Kanal Alt Fırsatları: {len(self.channel_opportunities)}")
        print(f"{Fore.RED}   Breakout Adayları: {len(self.breakout_candidates)}")
        print(f"{Fore.BLUE}   İdeal Pearson Sayısı: {len(self.ideal_pearson)}")

        # En yüksek Pearson değerleri
        if self.all_results:
            high_pearson = [r for r in self.all_results if abs(r.get('Pearson', 0)) &gt;= 0.9]
            print(f"{Fore.GREEN}  <img src="https://s.w.org/images/core/emoji/17.0.2/72x72/2b50.png" alt="⭐" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Yüksek Pearson (&gt;=0.9): {len(high_pearson)}")

    def save_failed_list(self, filename="basarisiz_regresyon_dosyalari.txt"):
        """Başarısız dosyaları kaydetme"""
        if self.failed_files:
            try:
                with open(filename, 'w', encoding='utf-8') as f:
                    f.write("# Başarısız Lineer Regresyon analizi dosyaları\n")
                    f.write(f"# Tarih: {datetime.now().strftime('%Y-%m-%d')}\n\n")
                    for file_name in self.failed_files:
                        f.write(f"{file_name}\n")
                print(f"{Fore.YELLOW} Başarısız dosyalar {filename} dosyasına kaydedildi.")
            except Exception as e:
                print(f"{Fore.RED}<img src="https://s.w.org/images/core/emoji/17.0.2/72x72/274c.png" alt="❌" class="wp-smiley" style="height: 1em; max-height: 1em;" /> Başarısız dosya listesi kaydetme hatası: {e}")

    def main(self):
        """Ana fonksiyon"""
        print(f"{Fore.CYAN} Lineer Regresyon ve Pearson Analizi Başlatılıyor...")
        print(f"{Fore.BLUE} Analiz Periyotları: {', '.join(map(str, self.pearson_periods))}")
        print(f"{Fore.BLUE} Özel Analiz Periyotları: {', '.join(map(str, self.analysis_periods))}")

        # Giriş dosyalarını bulma
        input_files = self.find_input_files()

        if not input_files:
            return

        print(f"{Fore.BLUE} Toplam işlenecek dosya: {len(input_files)}\n")

        # Dosyaları işleme
        for i, file_path in enumerate(input_files, 1):
            print(f"\n{Fore.MAGENTA}[{i}/{len(input_files)}] İşleniyor...")
            self.process_single_file(file_path)

        # EMA verilerini birleştirme
        self.merge_ema_data()

        # İstatistikleri hesaplama
        self.calculate_statistics()

        # Sonuçları kaydetme
        success = self.save_results()

        if success:
            self.print_summary()

        # Başarısız dosyaları kaydetme
        self.save_failed_list()

        print(f"\n{Fore.GREEN} Lineer regresyon analizi tamamlandı!")
        print(f"{Fore.BLUE} Ana dosya: StokData/lineer_regresyon_analiz.xlsx")
        print(f"{Fore.BLUE} Arşiv klasörü: StokData/LinearRegression/")


# Kullanım
if __name__ == "__main__":
    analyzer = LinearRegressionAnalyzer()
    analyzer.main()</pre>
<p>&nbsp;</p><p>The post <a href="https://www.kursatsenturk.com/2025/08/python-borsapin-lineer-regresyon-ve-pearson-analizi-betigi.html">Python BorsaPin Lineer Regresyon ve Pearson Analizi Betiği</a> first appeared on <a href="https://www.kursatsenturk.com">SDC</a>.</p>]]></content:encoded>
					
					<wfw:commentRss>https://www.kursatsenturk.com/2025/08/python-borsapin-lineer-regresyon-ve-pearson-analizi-betigi.html/feed</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
	</channel>
</rss><!--
Performance optimized by W3 Total Cache. Learn more: https://www.boldgrid.com/w3-total-cache/?utm_source=w3tc&utm_medium=footer_comment&utm_campaign=free_plugin


Served from: www.kursatsenturk.com @ 2026-05-31 05:20:21 by W3 Total Cache
-->