鱼C论坛

 找回密码
 立即注册
查看: 5193|回复: 1

[已解决]python 数据编辑求助 万分感谢啊。

[复制链接]
发表于 2017-3-25 00:11:05 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
需要把一个二维数组的值 按照某个规则,新建字段

所有数组的值都是1-5之间的值 下面是例子数据

id,A5,A10
1,5,3
2,1,4
3,2,4
4,3,4

规则就是 A5,A10下的数值,1-2 转成 'lev1',3转成'lev2', 4-5 转成‘lev3’

下面就是转换成的样子
id,A5,A10,new_A5,new_A10
1,5,3,lev3,lev2
2,1,4,lev1,lev3
3,2,4,lev1,lev3
4,3,4,lev2,lev3

我定义的函数是下面

data是原始数据

de_data=['A5','A10']

def def_jar(de_data):
    data_list=[]
    data_list=data.ix[:,de_data]
   
    for var_i in de_data:
        while data_list[var_i]==3:
            data['new_%s'%var_i]='lev1'
      
            if data_list[var_i]<=2:
                data['new_%s'%var_i]='lev2'
            else :
                data['new_%s'%var_i]='lev13'


结果报错


Traceback (most recent call last):
  File "F:\工作\panda.py", line 27, in <module>
    def_jar(de_data)
  File "F:\工作\panda.py", line 19, in def_jar
    while data_list[var_i]==3:
  File "C:\Program Files\Python35\lib\site-packages\pandas\core\generic.py", line 917, in __nonzero__
    .format(self.__class__.__name__))
ValueError: The truth value of a Series is ambiguous. Use a.empty, a.bool(), a.item(), a.any() or a.all().



最佳答案
2017-3-26 10:57:54
  1. def modify(file):
  2.     f=open(file)
  3.     nvalue=[]
  4.     for each_line in f:
  5.         if each_line.find('id') !=-1:
  6.             each_line=each_line[:-1]

  7.             temp=each_line.split(',')
  8.             temp.append('new_'+temp[1])
  9.             temp.append('new_' + temp[2]+'\n')

  10.             nvalue.append(temp)
  11.        else:
  12.             if each_line.find('\n')!=-1:
  13.                 each_line = each_line[:-1]
  14.             temp = each_line.split(',')
  15.             if temp[1]<'3':
  16.                 temp.append('lev1')
  17.             elif temp[1] =='3':
  18.                 temp.append('lev2')
  19.             else:
  20.                 temp.append('lev3')
  21.             if temp[2]<'3':
  22.                 temp.append('lev1\n')
  23.             elif temp[2] =='3':
  24.                 temp.append('lev2\n')
  25.             else:
  26.                 temp.append('lev3\n')
  27.             nvalue.append(temp)
  28.     f.close()
  29.     newf=open('new_'+file,'w')
  30.     for each_newline in nvalue:
  31.         newf.writelines(','.join(each_newline))
  32.     newf.close()

  33. filename=input('请输入文件名:')
  34. modify(filename)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2017-3-26 10:57:54 | 显示全部楼层    本楼为最佳答案   
  1. def modify(file):
  2.     f=open(file)
  3.     nvalue=[]
  4.     for each_line in f:
  5.         if each_line.find('id') !=-1:
  6.             each_line=each_line[:-1]

  7.             temp=each_line.split(',')
  8.             temp.append('new_'+temp[1])
  9.             temp.append('new_' + temp[2]+'\n')

  10.             nvalue.append(temp)
  11.        else:
  12.             if each_line.find('\n')!=-1:
  13.                 each_line = each_line[:-1]
  14.             temp = each_line.split(',')
  15.             if temp[1]<'3':
  16.                 temp.append('lev1')
  17.             elif temp[1] =='3':
  18.                 temp.append('lev2')
  19.             else:
  20.                 temp.append('lev3')
  21.             if temp[2]<'3':
  22.                 temp.append('lev1\n')
  23.             elif temp[2] =='3':
  24.                 temp.append('lev2\n')
  25.             else:
  26.                 temp.append('lev3\n')
  27.             nvalue.append(temp)
  28.     f.close()
  29.     newf=open('new_'+file,'w')
  30.     for each_newline in nvalue:
  31.         newf.writelines(','.join(each_newline))
  32.     newf.close()

  33. filename=input('请输入文件名:')
  34. modify(filename)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-17 10:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表