Terry J. Reedy <tjre...@udel.edu> added the comment:

> It is certainly unusual for n to be in the sequence, but not to be able to 
> find it.

Agreed. Doc Lib: 4.6. Sequence Types — str, bytes, bytearray, list, tuple, 
range says '''
s.index(i) index of the first occurence of i in s   
s.count(i) total number of occurences of i in s '''
so everything *in* a bytes should be valid for .index and .count.

>>> test = b'0120'
>>> z = b'0'
>>> zo = ord(z)
>>> z in test
True
>>> zo in test
True
>>> test.index(z)
0
>>> test.index(zo)
...
TypeError: expected an object with the buffer interface
>>> test.count(z)
2
>>> test.count(zo)
...
TypeError: expected an object with the buffer interface
# longer subsequences like b'01' also work

So I think the code for 3.2+ bytes.count() and bytes.index() should do the same 
branching as the code for bytes.__contains__.

The other functions you list, including .rindex are not general sequence 
functions but are string functions defined as taking subsequences as inputs. So 
they would never be used in generic code like .count and .index can be.

----------
nosy: +terry.reedy
stage:  -> test needed
title: Bytes objects do not accept integers to many functions -> Bytes.index() 
and bytes.count() do not accept byte ints
type:  -> behavior
versions: +Python 3.3

_______________________________________
Python tracker <rep...@bugs.python.org>
<http://bugs.python.org/issue12170>
_______________________________________
_______________________________________________
Python-bugs-list mailing list
Unsubscribe: 
http://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com

Reply via email to