a = fvec([0,1,2,3])
         assert a.dtype == 'float32'
         assert a.shape == (4,)
-        assert_equal (range(4), a)
+        assert_equal (list(range(4)), a)
 
     def test_vector_assign_element(self):
         a = fvec(default_size)
         a = fvec(1)
         a.T
         array(a).T
-        a = range(len(a))
+        a = list(range(len(a)))
 
     def test_wrong_values(self):
         self.assertRaises (ValueError, fvec, -10)
 
     def test_alpha_norm_of_fvec(self):
         a = fvec(2)
-        self.assertEquals (alpha_norm(a, 1), 0)
+        self.assertEqual (alpha_norm(a, 1), 0)
         a[0] = 1
-        self.assertEquals (alpha_norm(a, 1), 0.5)
+        self.assertEqual (alpha_norm(a, 1), 0.5)
         a[1] = 1
-        self.assertEquals (alpha_norm(a, 1), 1)
+        self.assertEqual (alpha_norm(a, 1), 1)
         a = array([0, 1], dtype='float32')
         from math import sqrt
         assert_almost_equal (alpha_norm(a, 2), sqrt(2)/2.)
         self.assertRaises (ValueError, alpha_norm, a, 1)
         # check 1d array
         a = array(range(10), dtype = 'float32')
-        self.assertEquals (alpha_norm(a, 1), 4.5)
+        self.assertEqual (alpha_norm(a, 1), 4.5)
 
     def test_alpha_norm_of_array_of_int(self):
         a = array(1, dtype = 'int')
         a = array([0,1,-1], dtype='float32')
         assert_almost_equal (zero_crossing_rate(a), 1./3. )
         a = array([0.]*100, dtype='float32')
-        self.assertEquals (zero_crossing_rate(a), 0 )
+        self.assertEqual (zero_crossing_rate(a), 0 )
         a = array([-1.]*100, dtype='float32')
-        self.assertEquals (zero_crossing_rate(a), 0 )
+        self.assertEqual (zero_crossing_rate(a), 0 )
         a = array([1.]*100, dtype='float32')
-        self.assertEquals (zero_crossing_rate(a), 0 )
+        self.assertEqual (zero_crossing_rate(a), 0 )
 
     def test_alpha_norm_of_array_of_float64(self):
         # check scalar fail
         a = array([[[1,2],[3,4]]], dtype = 'float64')
         self.assertRaises (ValueError, alpha_norm, a, 1)
         # check float64 1d array fail
-        a = array(range(10), dtype = 'float64')
+        a = array(list(range(10)), dtype = 'float64')
         self.assertRaises (ValueError, alpha_norm, a, 1)
         # check float64 2d array fail
-        a = array([range(10), range(10)], dtype = 'float64')
+        a = array([list(range(10)), list(range(10))], dtype = 'float64')
         self.assertRaises (ValueError, alpha_norm, a, 1)
 
     def test_fvec_min_removal_of_array(self):
 
     def test_unwrap2pi(self):
         unwrap2pi(int(23))
         unwrap2pi(float(23.))
-        unwrap2pi(long(23.))
+        unwrap2pi(int(23.))
         unwrap2pi(arange(10))
         unwrap2pi(arange(10).astype("int"))
         unwrap2pi(arange(10).astype("float"))
         #print zip(a, b)
 
         try:
-            print unwrap2pi(["23.","24.",25.])
-        except Exception, e:
+            print (unwrap2pi(["23.","24.",25.]))
+        except Exception as e:
             pass
 
     def test_unwrap2pi_takes_fvec(self):
         assert ( b <= pi ).all()
 
     def test_freqtomidi(self):
-        a = array(range(-20, 50000, 100) + [ -1e32, 1e32 ])
+        a = array(list(range(-20, 50000, 100)) + [ -1e32, 1e32 ])
         b = freqtomidi(a)
         #print zip(a, b)
         assert_equal ( isnan(array(b)), False )
         assert_equal ( array(b) < 0, False )
 
     def test_miditofreq(self):
-        a = range(-30, 200) + [-100000, 10000]
+        a = list(range(-30, 200)) + [-100000, 10000]
         b = miditofreq(a)
         #print zip(a, b)
         assert_equal ( isnan(b), False )
         assert_equal ( b < 0, False )
 
     def test_miditobin(self):
-        a = range(-30, 200) + [-100000, 10000]
+        a = list(range(-30, 200)) + [-100000, 10000]
         b = [ bintomidi(x, 44100, 512) for x in a ]
         #print zip(a, b)
         assert_equal ( isnan(array(b)), False )
         assert_equal ( array(b) < 0, False )
 
     def test_bintomidi(self):
-        a = range(-100, 512)
+        a = list(range(-100, 512))
         b = [ bintomidi(x, 44100, 512) for x in a ]
         #print zip(a, b)
         assert_equal ( isnan(array(b)), False )
         assert_equal ( array(b) < 0, False )
 
     def test_freqtobin(self):
-        a = range(-20, 50000, 100) + [ -1e32, 1e32 ]
+        a = list(range(-20, 50000, 100)) + [ -1e32, 1e32 ]
         b = [ freqtobin(x, 44100, 512) for x in a ]
         #print zip(a, b)
         assert_equal ( isnan(array(b)), False )
         assert_equal ( array(b) < 0, False )
 
     def test_bintofreq(self):
-        a = range(-20, 148)
+        a = list(range(-20, 148))
         b = [ bintofreq(x, 44100, 512) for x in a ]
         #print zip(a, b)
         assert_equal ( isnan(array(b)), False )
 
     def test_fail_name_not_string(self):
         try:
             window(10, 1024)
-        except ValueError, e:
+        except ValueError as e:
             pass
         else:
             self.fail('non-string window type does not raise a ValueError')
     def test_fail_size_not_int(self):
         try:
             window("default", "default")
-        except ValueError, e:
+        except ValueError as e:
             pass
         else:
             self.fail('non-integer window length does not raise a ValueError')
     def test_fail_not_fvec(self):
         try:
             level_lin("default")
-        except ValueError, e:
+        except ValueError as e:
             pass
         else:
             self.fail('non-number input phase does not raise a TypeError')
     def test_fail_not_fvec(self):
         try:
             db_spl("default")
-        except ValueError, e:
+        except ValueError as e:
             pass
         else:
             self.fail('non-number input phase does not raise a TypeError')
     def test_fail_not_fvec(self):
         try:
             silence_detection("default", -70)
-        except ValueError, e:
+        except ValueError as e:
             pass
         else:
             self.fail('non-number input phase does not raise a TypeError')
     def test_fail_not_fvec(self):
         try:
             level_detection("default", -70)
-        except ValueError, e:
+        except ValueError as e:
             pass
         else:
             self.fail('non-number input phase does not raise a TypeError')
 
         sigin = fvec(hop_s)
         zeros = fvec(hop_s)
         f = pvoc(buf_s, hop_s)
-        for i in xrange(hop_s):
+        for i in range(hop_s):
             sigin[i] = random() * 2. - 1.
         t2 = f.rdo( f(sigin) )
         t2 = f.rdo( f(zeros) )
 
         " running on silence gives 0 "
         p = pitch('default', 2048, 512, 32000)
         f = fvec (512)
-        for i in xrange(10): assert_equal (p(f), 0.)
+        for i in range(10): assert_equal (p(f), 0.)
 
     def test_run_on_ones(self):
         " running on ones gives 0 "
         p = pitch('default', 2048, 512, 32000)
         f = fvec (512)
         f[:] = 1
-        for i in xrange(10): assert_equal (p(f), 0.)
+        for i in range(10): assert_equal (p(f), 0.)
 
 class aubio_pitch_Sinusoid(TestCase):
 
 
                 for n in range(200):
                     vec = fvec(write)
                     g(vec, write)
-        except StandardError:
+        except Exception:
             pass
         else:
             self.fail("does not fail on too many files open")
                     total_frames += read
                     if read < f.hop_size: break
                 if 0:
-                    print "read", "%.2fs" % (total_frames / float(f.samplerate) ),
-                    print "(", total_frames, "frames", "in",
-                    print total_frames / f.hop_size, "blocks", "at", "%dHz" % f.samplerate, ")",
-                    print "from", f.uri,
-                    print "to", g.uri
+                    print ("read", "%.2fs" % (total_frames / float(f.samplerate) ) ),
+                    print ("(", total_frames, "frames", "in" ),
+                    print (total_frames / f.hop_size, "blocks", "at", "%dHz" % f.samplerate, ")" ),
+                    print ("from", f.uri ),
+                    print ("to", g.uri)
                 del_tmp_sink_path(sink_path)
 
     def test_read_and_write_multi(self):
                     total_frames += read
                     if read < f.hop_size: break
                 if 0:
-                    print "read", "%.2fs" % (total_frames / float(f.samplerate) ),
-                    print "(", total_frames, "frames", "in",
-                    print f.channels, "channels", "in",
-                    print total_frames / f.hop_size, "blocks", "at", "%dHz" % f.samplerate, ")",
-                    print "from", f.uri,
-                    print "to", g.uri,
-                    print "in", g.channels, "channels"
+                    print ("read", "%.2fs" % (total_frames / float(f.samplerate) ) ),
+                    print ("(", total_frames, "frames", "in" ),
+                    print (f.channels, "channels", "in" ),
+                    print (total_frames / f.hop_size, "blocks", "at", "%dHz" % f.samplerate, ")" ),
+                    print ("from", f.uri ),
+                    print ("to", g.uri ),
+                    print ("in", g.channels, "channels")
                 del_tmp_sink_path(sink_path)
 
     def test_close_file(self):
 
             vec, read = f()
             total_frames += read
             if read < f.hop_size: break
-        print "read", "%.2fs" % (total_frames / float(f.samplerate) ),
-        print "(", total_frames, "frames", "in",
-        print total_frames / f.hop_size, "blocks", "at", "%dHz" % f.samplerate, ")",
-        print "from", f.uri
+        print ("read", "%.2fs" % (total_frames / float(f.samplerate) ) ),
+        print ("(", total_frames, "frames", "in" ),
+        print (total_frames / f.hop_size, "blocks", "at", "%dHz" % f.samplerate, ")" ),
+        print ("from", f.uri)
         return total_frames
 
     def test_samplerate_hopsize(self):
         for p in list_of_sounds:
             try:
                 f = source(p, -1)
-            except ValueError, e:
+            except ValueError as e:
                 pass
             else:
                 self.fail('negative samplerate does not raise ValueError')
         for p in list_of_sounds:
             try:
                 f = source(p, 0, -1)
-            except ValueError, e:
+            except ValueError as e:
                 pass
             else:
                 self.fail('negative hop_size does not raise ValueError')
             vec, read = f.do_multi()
             total_frames += read
             if read < f.hop_size: break
-        print "read", "%.2fs" % (total_frames / float(f.samplerate) ),
-        print "(", total_frames, "frames", "in",
-        print f.channels, "channels and",
-        print total_frames / f.hop_size, "blocks", "at", "%dHz" % f.samplerate, ")",
-        print "from", f.uri
+        print ("read", "%.2fs" % (total_frames / float(f.samplerate) ) ),
+        print ("(", total_frames, "frames", "in" ),
+        print (f.channels, "channels and" ),
+        print (total_frames / f.hop_size, "blocks", "at", "%dHz" % f.samplerate, ")" ),
+        print ("from", f.uri)
         return total_frames
 
 if __name__ == '__main__':