skyhouse 发表于 2022-10-25 16:59:53

如何取execl文件数列的数字的一部分

excel里面有一列数列,我只想取其中的一部分(除去最后两个数,其他都要。该怎么写代码,
怎样效率较高,是在原数值上修改还是生成一列新数列?

假设原数值如下

time
9452145
10301225
10254512
11054248


需要取成如下的数字

time
94521
103012
102545
110542

除去最后两位数字,其他都需要。

麻烦大神了。

wp231957 发表于 2022-10-25 17:31:57

如果是在excel中操作,当然是新生成一列,比较简单

skyhouse 发表于 2022-10-25 17:54:15

要在python中用代码完成

灰晨 发表于 2022-10-25 18:59:01

import openpyxl

# 打开Excel
book = openpyxl.load_workbook('1.xlsx')# 表名自己换
# 第几个表
sheet = book] # 默认第一个,【0】
# 获取每行数据,存列表rows_data里
rows_data = list(sheet.rows)
# 关闭Excel
book.close()

lists = [] # 存新数据的列表
# 遍历每一行
for a_row in rows_data:
    # 获取第n列的值,这里第【0】列,就是第一列
    number = a_row.value
    # 获取的数字转字符串,去掉字符串后两位,赋值给new_number
    new_number = str(number)[:-2]
    # 新数字存进列表里,可以转回整数
    lists.append(int(new_number))

print(lists)

阿奇_o 发表于 2022-10-25 19:04:48

df['new'] = df.time.str[:-2]
df
       time   new
0   9452145   94521
110301225103012
210254512102545
311054248110542

skyhouse 发表于 2022-10-25 21:25:04

谢谢楼上2位,都是我想要的结果,最佳答案给先答的同学。
页: [1]
查看完整版本: 如何取execl文件数列的数字的一部分