pandas基础学习笔记(简略版)


1、DataFrame

既有行索引(index)又有列索引(columns)的二维数组

# 生成dataframe
stock=[f'股票{i}' for i in range(10)]
date=pd.date_range(start='20211201',priods=5,freq='B')
data1=pd.DataFrame(stock_change,index=stock,columns=date)

data2=pd.DataFrame({'month':[1,2,3,45,5],
                  'year':[1,2,3,4,5],
                  'sale':[20,30,50,40,80]})

# dataframe的方法与属性
# 方法
data.head()
data.tail()
# 属性
data.columns
data.index
data.values
data.shape
data.dtype

# 重设索引
stock_=[f'股票_{i}' for i in range(10)]
data.index=stock_
# 扔掉原有的行索引,用1,2,3,4代替
data.reset_index(drop=Flase)
# 用‘股票0’列做索引
data.set_index('股票0',drop=True)

2、series

带行索引的一维数组

# 创建索引
data1=pd.Series({'red':10,'yellow':20,'black':40})
data2=pd.Series([1,2,3,4,5],index=['r','y','b','k','c'])

3、基本数据操作

  1. 索引操作

    data['columns名']
    data['columns名']['index名']
    data.iloc[0][0]
    data.loc['index名']['columns名']
  2. 赋值操作

    # 索引=值
  3. 排序操作

    data.sort_index(ascending=False)
    data.sort_values(by='行列名',ascending=True)

4、DataFrame 运算

  1. 算数运算

    和numpy中 array与数运算类似

    data['股票0']+1
    data['股票1']*3
  2. 逻辑运算

    # 逻辑运算符  < > | &
    data['股票0']>0
    (data['股票0']>0)&(data['股票1']>0)
    # 逻辑运算函数
    data['股票0'].isin([3,2,1]) # 3,2,1在不在里面
    data.query('股票0>0&股票1<0')
  3. 统计运算

    # 1、df.describe()
    data.decribe()
    # 2、df.idxmax(axis=0)
    data.idxmax(axis=0)
    # 3、cumsum、cummax、cummin、cumprod(前n个数的积)
    data['股票0'].cumsum()
  4. 自定义运算

    # df.apply(func,axis=0)
    data.apply(lambda x: x.max()-x.min())

5、pandas绘图


# 1、df.plot(x=none,y=none,kind='line')

data.plot(x="volume",y='turnover',kind='scatter')
# 2、Series.plot(kind='line')

sr.plot(kind='line')

6、文本的读取与存储

  • csv

    # 1、读取想要的列
    data=pd.read_csv('./1.csv',usecols=['列名'])
    # 2、给没有列名的图表加列名
    data=pd.read_csv('./2.csv',names=['列名'])
    # 3、保存文件
    data.iloc[:,0].to_csv('test.csv',index=False)
    data[0:5].to_csv('test1.csv',columns=['列名'],index=False)
    # 4、丢弃不想要的列
    data=data.drop(['ma','列名',axis=1])
  • hdf5

    # hdf5文件读取与存储时需要指定一个键(类似matlab里的变量名)
    data=pd.read_hdf('./1.h5',key='变量名')
    data.iloc[,0:5].to_hdf("2.h5",key='变量名')
  • json

    data=pd.read_json('./1.json',orient='records',lines=True)
    data.iloc[:,1:5].to_json(('2.json',orient='records',lines=True))

文章作者: 乔彬
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 乔彬 !
  目录