import pandas as pd
import numpy as np
from lib_001_decorator_log_funcname import decorator_log_funcname
from env_config import *
csv_a = data_path + 'a.csv'
csv_b = data_path + 'b.csv'
csv_r = data_path + 'r.csv'
csv_t = data_path + 't.csv'
csv_p = data_path + 'p.csv'
csv_x = data_path + 'x.csv'
df = pd.DataFrame()
print(type(df))
df_x = pd.read_csv(csv_x)
df_p = pd.read_csv(csv_p)
@decorator_log_funcname
def _test_load_csv():
    global df
    df = pd.read_csv( csv_a, names=["col1","col2","col3"] )
    print(type(df))
    print(df)
@decorator_log_funcname
def _test_dump_csv():
    df.to_csv(csv_r)
@decorator_log_funcname
def _test_load_table_csv():
    df = pd.read_csv(csv_t, index_col='rowtitle' )
    print(df)
@decorator_log_funcname
def _test_load_panda_csv():
    global df
    df = pd.read_csv(csv_p)
    print(df)    
@decorator_log_funcname
def _test_dump_panda_csv():
    global df
    print(df)
    df.to_csv(csv_r, index=False)
@decorator_log_funcname
def _test_load_panda_csv_change_colname():
    global df
    lname = ["g1","g2","g3"]
    df = pd.read_csv(csv_p, header=0, names=lname )
    #? for del header, header=0
    # for add header, names=lname
    print(df)        
@decorator_log_funcname
def _test_df_count_col():
    pass
    global df_p
    print(len(df_p.columns.to_list()))
@decorator_log_funcname
def _test_df_count_row():
    global df_p
    row = df_p.count()
    print(type(row))
    print(row)
    print(row.to_list())
    rr = df_p['col1'].count()
    print(rr)
@decorator_log_funcname
def _test_df_insert_row():
    df1 = df_p
    dfi = pd.DataFrame( [[44,55,66],], columns=['col1','col2','col3'] )
    print('dfi==\n',dfi)
    xx = _func_df_insert_row(1,df1,dfi)
    print("xx==\n",type(xx), '\n', xx )
@decorator_log_funcname
def _func_df_insert_row(idx, df_base, df_insert):
    df1 = df_base[:idx]
    df2 = df_base[idx:]
    dff = df1.append(df_insert).append(df2).reset_index(drop=True) 
    return dff
@decorator_log_funcname
def _func_df_insert_row_at_0(df_base, ls_in):
    df_base.loc[-1] = ls_in
    df_base.index = df_base.index + 1
    print(type(df_base.index))
    print(df_base.index)
    print(df_base)
    df_base.sort_index( inplace=True)
    print(df_base)
    return df_base    
@decorator_log_funcname
def _test_df_update_append_row():
    df1 = df_p
    print(df1)
    df1.loc[0] = ['11','22','33']
    print(df1)
    df1.loc[2] = ['33','333','3333']
    print(df1)
@decorator_log_funcname
def _test_df_get_some_rows_as_sub_df():
    df1 = df_p
    print(df1)
    print(df1[0:1])
@decorator_log_funcname
def _test_df_del_row():
    global df_p
    df1 = df_p
    df2 = df1.drop([1])
    print(df2)
    print(df1)
    print(df_p)
    df1.drop([1], inplace=True)
    print(df1)
    pass
@decorator_log_funcname
def _test_df_update_col():
    df1 = df_p
    print(df1)
    df1['col1'] = 88
    print(df1)
    df1['col2'] = [55,44]
    print(df1)
    print(df1.index.stop)  #
@decorator_log_funcname
def _test_df_insert_col():
    global df_p
    print(df_p)
    df1 = df_p
    ll = [10,11]
    print(df1)
    df1.insert( loc=0, column='col0', value=ll)
    print(df1)
@decorator_log_funcname
def _test_df_del_col():
    global df_p
    print(df_p)
    df1 = df_p
    print(df1)
    df1.drop('col1', axis=1, inplace=True)
    print(df1)
@decorator_log_funcname
def _test_df_del_row_with_drop():
    global df_p
    print(df_p)
    df1 = df_p
    print(df1)
    df1.drop(1, axis=0, inplace=True)
    print(df1)
@decorator_log_funcname
def _test_df_del_col_with_del():
    global df_p
    print(df_p)
    df1 = df_p
    print(df1)
    del df1['col1']
    print(df1)    
@decorator_log_funcname
def _test_df_set_cell():
    global df_p
    print(df_p)
    df1 = df_p
    print(df1)
    df1.loc[1,'col2'] = 88
    print(df1)
@decorator_log_funcname
def _test_df_check_NaN():
    global df_p
    print(df_p)
    df1 = df_p
    print(df1)
    df1.loc[1,'col2'] = np.nan
    print(df1)
@decorator_log_funcname
def _test_df_get_sub_col():
    global df_p
    print(df_p)
    df1 = df_p
    print(df1)
    df2 = df1[['col1','col3']]
    print(df2)
@decorator_log_funcname
def _test_df_get_sub_row():
    pass
@decorator_log_funcname
def _test_df_set_col_type():
    global df_p
    print(df_p)
    df1 = df_p
    print(df1)
    print(df1.dtypes)
    df1['col1'] = df1['col1'].astype(float)
    print(df1)
    print(df1.dtypes)    
@decorator_log_funcname
def _test_df_sort_value():
    global df_p
    print(df_p)
    df1 = df_p.sort_values( 'col1', ascending=False )
    print(df_p)
    print(df1)
@decorator_log_funcname
def _test_df_get_header():
    print(df_p)
    head = df_p.columns.to_list()
    print(type(head))
    print(head)
    pass
@decorator_log_funcname
def _test_other():
    # global df
    # df = pd.read_csv(csv_x)
    # print(df)
    # print(len(df.columns.to_list()))
    # print(df.columns.to_list())
    #df.to_csv(csv_r, index=False)
    pass
@decorator_log_funcname
def _test( ):
    #_test_load_csv()
    #_test_dump_csv()
    #_test_load_table_csv()
    #_test_load_panda_csv()
    #_test_dump_panda_csv()
    #_test_load_panda_csv_change_colname()
    #_test_df_count_col()
    # _test_df_count_row()
    # _test_df_insert_row()
    # _func_df_insert_row_at_0(df_p,[100,101,102])
    # _test_df_update_append_row()
    #_test_df_get_some_rows_as_sub_df()
    # _test_df_del_row()
    #_test_df_update_col()
    #_test_df_insert_col()
    # _test_df_del_col()
    # _test_df_del_row_with_drop()
    # _test_df_del_col_with_del()
    # _test_df_set_cell()
    # _test_df_check_NaN()
    # _test_df_get_sub_col()
    _test_df_set_col_type()
    # _test_df_sort_value()
    #_test_df_get_header()
    # _test_other()
    
if __name__ == '__main__':
    _test()

python_test_5001_Moudle_pandas的更多相关文章

  1. Django商城项目笔记No.18商品部分-数据表创建

    数据库表设计 在电商中对于商品,有两个重要的概念:SPU和SKU SPU = Standard Product Unit (标准产品单位) SPU是商品信息聚合的最小单位,是一组可服用.易检索的标准化 ...

  2. day04记

    useGeneratedKeys useGeneratedKeys这个只在insert语句中有效,正常情况下useGeneratedKeys默认为false 当useGeneratedKeys为tru ...

随机推荐

  1. window 运行 jar包方式

    所有文件 1.将jar包指定为bat批处理文件,然后可以双击启动 新建start2.txt 编辑保存一下内容,修改start2.txt后缀为bat,点击运行(此方法当前命令窗口关闭后,程序也关闭) j ...

  2. nodejs npm错误Error:UNKNOWN:unknown error,mkdir 'D:\Develop\nodejs\node_global'at Error(可行)

    错误原因 在设置npm的cache和predix时,因为使用参考其他教程照抄,而没有修改为本机对应路径,本机上并没有这个地址,因此造成了错误. npm config set cache "D ...

  3. 【django-vue】前端取消默认样式 main.js配置 后端主页模块接口 跨域问题详解 项目自定义配置 git介绍和安装

    目录 回顾 上节课回顾 今日内容 1 前端全局样式和js配置 1.1 global.css 1.2 settings.js 1.3 main.js 2 后端主页模块接口 三种开发模式 模型父类Base ...

  4. Angular 发布IIS

    1.IIS服务器需要安装插件 安装 Url https://www.iis.net/downloads/microsoft/url-rewrite 2.修改配置 在src目录下,添加 web.conf ...

  5. 滑动窗口模板 leetcode 209题

        """ 给定一个含有 n 个正整数的数组和一个正整数 target . 找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, nums ...

  6. 野火FreeRTOS第九章(任务延时列表)实验意外解决办法

    书中说:main()函数内容与第8章一样,无需改动. 但实际代码中,添加了在开启调度前关闭中断的函数,如下红色代码所示: int main(void) { /* 硬件初始化 */ /* 将硬件相关的初 ...

  7. 552. 学生出勤记录 II (Hard)

    问题描述 552. 学生出勤记录 II (Hard) 可以用字符串表示一个学生的出勤记录,其中的每个字符用来标记当天的出勤情况(缺勤.迟到.到场).记录中只含下面三种字符: 'A':Absent,缺勤 ...

  8. react 04 生命周期

    生命周期的三个状态 mounting  : 组件插入到dom updating: 将数据更新到dom unmounting:将组件移除dom 生命周期的钩子函数 ComponentWillMount: ...

  9. VS 生成事件 xcopy 报错的解决方法

    出现这种情况有可能原因有2种可能: 1.目标文件夹设为只读:此时报错:MSB3073 代码4 ,输出显示:访问遭到拒绝. 解决:去掉文件夹只读属性. 2.缺少环境变量:报错为::MSB3073 代码9 ...

  10. 00_java基础笔记

    _01_命令提示符 //cmd的操作(Ms-DOS) /* * 进文件夹:cd 文件夹名 * 进多级文件:cd 文件夹1\文件夹2 * 返回上一级:cd .. * 回根路径:cd \ * 查看当前内容 ...