python 改变数据框列顺序

Python018

python 改变数据框列顺序,第1张

在合并两个数据时,发现两个df的列顺序不一致,得把其中的一个给修改下;

方法一:

把需要的列顺序给弄成一个list,然后再选取;

order_columns = ['user_id', 'name', 'create_time']

然后再选取数据赋给一个新的数据框;

df1 = df[order_columns]

方法二:

先把需要调整的列的数据拿出来,之后,再将这个列删掉,最后,再用插入的方式把这个列调整到对应的位置上。

df_id = df.id

df = df.drop('id',axis=1)

df.insert(0,'id',df_id)

详细参考:

https://blog.csdn.net/a19990412/article/details/81945315

亲你好,Python教程:在python中对列表进行排序详解 Python知识,本文学习的是《在Python中对列表进行排序详解》。本知识点主要内容有:使用列表对象的sort()方法进行排序、使用内置的sorted()函数进行排序、使用reverse()方法进行反向排序。

在Python实际开发中,会经常需要用到对列表进行排序。下面站长在线对列表的排序讲解几种常用的方法:

1、使用列表对象的sort()方法进行排序。

列表对象提供了sort()方法用于对原列表中的元素进行排序。排序以后,原列表中的元素顺序将发生改变。列表对象的sort()方法的语法格式如下:

listname.sort(key=None,reverse=False)

相关的参数说明如下:

listname:表示要进行排序的列表。

key:表示指定一个从每个列表元素中提取一个比较键。(列如,设置“key=str.lower”表示在排序时不区分字母的大小写)。

reverse:可选参数,如果将其值指定为True,则表示降序排序;如果将其指定为False,则表示升序排列。默认为升序排列。

列如,某中学初三1班的10名男学生的数学成绩,然后应用sort()方法对其进行排序,代码如下:

s = [93,95,86,98,99,99,89,100,100,97]

print("原列表:",s)

s.sort()

print("升序:",s)

s.sort(reverse=True)

print("降序:",s)

执行结果如下:

原列表: [93, 95, 86, 98, 99, 99, 89, 100, 100, 97]

升序: [86, 89, 93, 95, 97, 98, 99, 99, 100, 100]

降序: [100, 100, 99, 99, 98, 97, 95, 93, 89, 86]

>>>

使用sort()方法除了可以对数值进行排序,还可以多字符串进行排序。对字符串进行排序默认区分大小写,如果想不区分大小写,则需要指定其key参数。

列如,定义保存一个大小写不同的英文字符串列表,然后应用sort()方法对其进行排序,代码如下:

s = ['hello','polly','Lucy','Lily','Han Meimei']

s.sort()

print("区分字母大小写:",s)

s.sort(key=str.lower)

print("不区分字母大小写:",s)

运行结果如下:

区分字母大小写: ['Han Meimei', 'Lily', 'Lucy', 'hello', 'polly']

不区分字母大小写: ['Han Meimei', 'hello', 'Lily', 'Lucy', 'polly']

>>>

说明:sort()方法对列表排序时,最中文的支持不好,排序的结果与我们常用的按拼音排序或者笔画排序都不一致。要想实现对中文内容的排序,需要重新编写相应的方法,不能直接使用sort()方法