python怎么只保留某列前几个数字

  统计/机器学习 Python    浏览次数:2782        分享
0

比如

name              date 

   a              20110928

   b              20121124

   c              20130326

把date保留成

2011

2012

2013


谢谢

 

heyyyyy   2020-11-21 10:40



   2个回答 
0

假定你的文件是csv哈,你用pandas读取csv文件操作DataFrame就可以了,具体去查apply用法就懂了

import pandas as pd


def get_year(date):
    for i in range(4):
        date = date // 10
    return date


a = pd.DataFrame([['a', 20110928],
                   ['b', 20121124],
                   ['c', 20130326],])

a[1] = a.apply(lambda x: get_year(x[1]), axis = 1)
print(a)

输出:

   0     1
0  a  2011
1  b  2012
2  c  2013


SofaSofa数据科学社区DS面试题库 DS面经

eleve11   2020-11-24 23:54

0


import pandas as pd
df.date = df.date.apply(lambda x: str(x)[:4]) # 这里要看你原始date列的类型

解决了

SofaSofa数据科学社区DS面试题库 DS面经

stan   2020-12-02 15:50



  相关讨论

python如何删除dict中的一个key?

如何将csv中多行变成一行

怎么让DataFrame按照某一列绝对值从小到按排列?

python里的TYPE_CHECKING是什么作用?

Python 处理问题

from __future__ import division是什么意思

python的dataframe如何重新排列行或者列

python里求累计和

我def了两个参数 但是给2个却报错

python里的continue是什么意思

  随便看看

如何检验两个样本是同分布的?

【站务】我们回来了

什么是K-Modes(K众数)聚类法?

python sklearn模型中random_state参数的意义

怎么给plt.subplot加一个主标题?