Here's the solution I came up with:
import numpy
def adj(attr):
if attr==None:
return attr
else:
return attr-1
def adjust_slice(x):
if isinstance(x,int):
return x-1
elif isinstance(x,slice):
return slice(*[adj(attrib) for attrib in (x.start,x.stop,x.step)])
elif isinstance(x,list):
return slice(x[0]-1,x[-1]-1,1)
else:
raise Exception("Expected slice, list, or int.")
class array_starting_at_one(list):
def __init__(self,np_array):
self.np_array = numpy.array(np_array)
def __getitem__(self,i):
if isinstance(i,int):
i=i-1
elif isinstance(i,tuple):
i = tuple([adjust_slice(x) for x in i])
else:
return array_starting_at_one(self.np_array[adjust_slice(x)])
return self.np_array[i]
def __setitem__(self,i,y):
if isinstance(i,int):
self.np_array[i-1] = y
elif isinstance(i,tuple):
self.np_array[tuple([adjust_slice(x) for x in i])] = y
else:
self.np_array[adjust_slice(x)] = y
def __getslice__(self,i,j):
return array_starting_at_one(self.np_array[(i-1):(j-1)])
def __setslice__(self,i,j,y):
self.np_array[i-1:j-1]=y
def __repr__(self):
print self.np_array
def __str__(self):
return str(self.np_array)
It worked for what I needed it to, but I didn't take the time to test it too carefully, so please use with caution.
__getitem__in your child class