On Sa, 2014-08-30 at 09:04 +0100, Sebastian Berg wrote:
> On Fr, 2014-08-29 at 22:10 -0400, Benjamin Root wrote:
> > Consider the following:
> > 
> > a = np.array([(1, 'a'), (2, 'b'), (3, 'c')], dtype=[('foo', 'i'),
> > ('bar', 'a1')])
> > 
> > b = np.append(a, (4, 'd'))
> > Traceback (most recent call last):
> >   File "<stdin>", line 1, in <module>
> >   File
> > "/home/ben/miniconda/lib/python2.7/site-packages/numpy/lib/function_base.py",
> >  line 3555, in append
> >     return concatenate((arr, values), axis=axis)
> > TypeError: invalid type promotion
> > b = np.insert(a, 4, (4, 'd'))
> > Traceback (most recent call last):
> >   File "<stdin>", line 1, in <module>
> >   File
> > "/home/ben/miniconda/lib/python2.7/site-packages/numpy/lib/function_base.py",
> >  line 3464, in insert
> >     new[slobj] = values
> > ValueError: could not convert string to float: d
> > 
> 

Actually, for insert it is easy to fix
(https://github.com/numpy/numpy/pull/5022), for append there are some
difficulties, because the dtype is not forced to be the arrays dtype,
but gotten from both the original and the appended value currently.

- Sebastian


> Ooops, nice bug in there, might have been me :) (will open a PR). 
> 
> - Sebastian
> 
> > 
> > In my original code snippet I was developing which has a more involved
> > dtype, I actually got a different exception:
> > b = np.append(a, c)
> > Traceback (most recent call last):
> >   File "<stdin>", line 1, in <module>
> >   File
> > "/home/ben/miniconda/lib/python2.7/site-packages/numpy/lib/function_base.py",
> >  line 3553, in append
> >     values = ravel(values)
> >   File
> > "/home/ben/miniconda/lib/python2.7/site-packages/numpy/core/fromnumeric.py",
> >  line 1367, in ravel
> >     return asarray(a).ravel(order)
> >   File
> > "/home/ben/miniconda/lib/python2.7/site-packages/numpy/core/numeric.py", 
> > line 460, in asarray
> >     return array(a, dtype, copy=False, order=order)
> > ValueError: setting an array element with a sequence.
> > 
> > 
> > Luckily, this works as a work-around:
> > >>> b = np.append(a, np.array([(4, 'd')], dtype=a.dtype))
> > >>> b
> > array([(1, 'a'), (2, 'b'), (3, 'c'), (4, 'd')], 
> >       dtype=[('foo', 'i'), ('bar', 'S1')])
> > 
> > 
> > 
> > The same happens whether I enclose the value with square bracket or
> > not. I suspect that this array type just wasn't considered when its
> > checking logic was developed. This is with 1.8.2 from miniconda.
> > Should we consider this a bug or are structured arrays just not
> > expected to be modified like this?
> > 
> > 
> > Cheers!
> > 
> > Ben Root
> > 
> > _______________________________________________
> > NumPy-Discussion mailing list
> > NumPy-Discussion@scipy.org
> > http://mail.scipy.org/mailman/listinfo/numpy-discussion
> 
> 
> _______________________________________________
> NumPy-Discussion mailing list
> NumPy-Discussion@scipy.org
> http://mail.scipy.org/mailman/listinfo/numpy-discussion
> 


_______________________________________________
NumPy-Discussion mailing list
NumPy-Discussion@scipy.org
http://mail.scipy.org/mailman/listinfo/numpy-discussion

Reply via email to