python¿¡¼­ Àоî¿Â CSV µ¥ÀÌÅ͸¦ ÀÏÁ¤°£°ÝÀ¸·Î ¹«½ÃÇÏ°í scatter ±×¸®±â Áú¹®..

python   
   Á¶È¸ 5607   Ãßõ 1    

 

혹 python 다루시는 분이 계실것 같아 여쭤봅니다..


python에서 CSV 데이터를 읽어 온 뒤 scatter로 뿌리는 문제입니다.

CSV 데이터는 x_1, y_1, y_2로 되어 있고, 각 10,000개 씩의 값을 가진 20,000개의 좌표점입니다.


이를 대략 x축을 기준으로 1000간격에 해당하는 좌표점만 띄엄띄엄 scatter로 뿌리고 싶습니다.

이를 반복문을 써서


for step in range(10001):

         if step % 1000 == 0:

                x = x_1

                y1 = y_1

                y2 = y_2

x_1, y_1, y_2의 데이터를 1000간격씩 x, y1, y2에 새로 저장해


x,y1 그리고 x,y2를 scatter로 뿌리면 될꺼라 생각했는데, 생각이랑 다르게 안되네요.

어떻게 해야될까요..


아래는 제가 짜본 코드입니다.


import pandas as pd
import matplotlib.pyplot as plt

dataset=pd.read_csv("Basic.csv");
y_1= dataset.iloc[:,1].values.astype(float)
y_2= dataset.iloc[:,2].values.astype(float)
x_1= dataset.iloc[:,0].values.astype(float)


for step in range(10001):
    if step % 1000 == 0:
        y1 = y_1
        y2 = y_2
        x = x_1


plt.scatter(x, y1, marker='s', color='b')
plt.annotate('maximum: 0.3669', xy=(9991,0.3669), xytext=(6000,0.2), arrowprops=dict(arrowstyle="->", connectionstyle="arc3, rad=0.2"))

plt.scatter(x, y2, marker='^', color='r')
plt.annotate('maximum: 0.4869', xy=(9643,0.4869), xytext=(6000,0.65), arrowprops=dict(arrowstyle="->", connectionstyle="arc3, rad=-0.2"))


plt.ylim(0,1.0)

plt.legend(loc='upper left', frameon=False)

plt.show()


ªÀº±Û Àϼö·Ï ½ÅÁßÇÏ°Ô.
º¯¼±ÁÖ 2017-05
pythonÀº Àß ¸ð¸¨´Ï´Ù¸¸, Á¦°¡ »ç¿ëÇÏ´Â R¿¡¼­ Àú¶ó¸é ´ÙÀ½°ú °°Àº ¹æ¹ýÀ¸·Î ¹®Á¦¸¦ Ç®¾îº¸°Ú½À´Ï´Ù.
¼øȯ±¸¹®¿¡ ÀÇÇÏ¿© Á¡À» Ãâ·ÂÇÏ´Â ¹æ½ÄÀ¸·Î Äڵ带 Â¥½Å °Í °°½À´Ï´Ù. ÀÌ·² °æ¿ì¿¡ ù ¹ø°³ª ±× ±Ùó °ªÀ» °¡Áö´Â ´Ù¸¥ °ªÀº plot¿¡ º¸ÀÏ ¼ö ÀÖÀ¸³ª ±×·¸Áö ¾ÊÀº °æ¿ì¿¡´Â ù ¹ø° plot ¿µ¿ª ¹ÛÀÇ °ªÀ̶ó¸é º¸ÀÌÁö ¾Ê½À´Ï´Ù. ÃÖ´ë°ª°ú ÃÖ¼Ò°ªÀ» ¹Ì¸® È®ÀÎÇÏ¿© ÀÌ ¿µ¿ªÀ» ¹Ì¸® plot¿¡ Á¤ÀÇÇÏ´Â ¹æ¹ýÀÌ ÀÖ½À´Ï´Ù.
±×º¸´Ù ÆíÇÑ ¹æ¹ýÀ¸·Î´Â ±× ¸î °³ÀÇ °ªÀ» °¡Áö´Â data ¸¦ ÃßÃâÇÏ¿© º°µµÀÇ data ¸¦ ¸¸µç ´ÙÀ½¿¡ ±×³É plot Çغ¸°Ú½À´Ï´Ù.
python 2017-05
»ý°¢Çغ¸´Ï ¹Ýº¹±¸¹®¿¡¼­, 10000À» 1000À¸·Î ³ª´«°ªÀÇ ³ª¸ÓÁö°¡ 0ÀÏ ¶§¸¶´Ù x_1, y_1, y_2ÀÇ ¸®½ºÆ® °ªÀÇ ÀϺΠ¿ä¼Ò¸¦ ÃëÇØ x, y1, y2¿¡ ÀúÀåÇؾßÇϴµ¥,

±âÁ¸ÀÇ ¹Ýº¹¹®¿¡¼­ ¿ä¼Ò°¡ ¾Æ´Ñ, ¸®½ºÆ® °ª Àüü¸¦ °è¼ÓÇؼ­ º¹»çÇÏ°í ÀÖ´õ¶ó±¸¿ä.....

±×·¡¼­ °£´ÜÇÏ°Ô ¸®½ºÆ®¿¡¼­ ¿ä¼Ò°ª¸¸ ã¾Æ ´Ù¸¥ º¯¼ö¿¡ ÀúÀåÇϵµ·Ï ³Ö¾î¼­ Ç®¾ú½À´Ï´Ù.

Ȥ ±Ã±ÝÇϽŠºÐ ÀÖÀ»Áöµµ ¸ô¶ó ÄÚµå ¾Æ·¡ ºÙÀÔ´Ï´Ù.


import numpy as np
import pandas as pd
import matplotlib.pyplot as plt

dataset=pd.read_csv("Model 1 and 2 compariosn.csv");
y_1= dataset.iloc[:,1].values.astype(float)
y_2= dataset.iloc[:,2].values.astype(float)
x_1= dataset.iloc[:,0].values.astype(float)


x = np.zeros(40, dtype=float)
y1 = np.zeros(40, dtype=float)
y2 = np.zeros(40, dtype=float)



for step in range(x_1.size):
    if step % 250 == 0:
      stepnew=round(step/250)
        y1[stepnew] = y_1[step]
        y2[stepnew] = y_2[step]
        x[stepnew] = x_1[step]


plt.scatter(x, y1, marker='o', color='b')
plt.annotate('maximum: 0.3669', xy=(9991,0.3669), xytext=(6000,0.2), arrowprops=dict(arrowstyle="->", connectionstyle="arc3, rad=0.2"))

plt.scatter(x, y2, marker='^', color='r')
plt.annotate('maximum: 0.4869', xy=(9643,0.4869), xytext=(6000,0.65), arrowprops=dict(arrowstyle="->", connectionstyle="arc3, rad=-0.2"))

plt.xlim(x.min()-1000, x.max()+1000)
plt.ylim(0,1.0)

plt.legend(loc='upper left', frameon=False)

plt.show()


QnA
Á¦¸ñPage 1965/5727
2015-12   1776037   ¹é¸Þ°¡
2014-05   5250936   Á¤ÀºÁØ1
2016-05   4513   ³×¹ö½æ¸Ó
2020-12   5037   À嵿°Ç2014
2022-06   2262   ±îÄ¡»ê°³²ÜÅÊ
2011-03   7050   ³ª³Ê¿ì¸®
2019-09   3619   Ãë¹ÌÄÄ
2013-10   7816   Lucifer
2020-12   3586   ½ÎÀÌÁ¦ÀÌ
2011-04   8646   ÀÌÁ¾Çöoph
2015-03   4493   2CPUÃÖÁÖÈñ
2020-12   2342   2CPUÃÖÁÖÈñ
2020-12   4270   °­Çѱ¸
2016-05   5531   Ãֽÿµ
2020-12   3463   ±èÁØÀ¯
2022-06   1974   ±îÄ¡»ê°³²ÜÅÊ
2018-07   3920   ±è°Ç¿ì
2022-06   1731   õ¹øµÕ°³
2015-03   8687   »ßµ¹À̽½ÇÄÀÌ
2024-02   1430   °ø¾ËÀÌ
2017-04   3295   ½ÅÀº¿Ö
2019-09   3784   Àü¼³¼ÓÀǹ̡¦