Writing bytes out

孤人 提交于 2020-01-07 04:39:08

问题


I am using Pyserial to write out bytes to a connection.

One of the things I have been struggling with is figuring out how to write out exactly the bits that I want. I have had success writing out the bytes of a strings ascii form, such as

variable = 'h'.encode()
serial.write(variable)

And that will write out the bits of H succesfully. However if I do something like that with b'\b001' it won't write out 001 like I had hoped it would.

Is there a way to do this so I can simply define variables using 1 and 0 and then use the write function.

I tried also defining like this:

y = 0x13
out = s.write(y)

Which according to the write function's documentation, the function returns the amount of bytes written. When I ran this specific code it returned 19


回答1:


If I understand correctly you are trying to find a way to send binary data as python bytes objects, and hex data as python bytes objects (in the second part).

it may be counter intuitive, but pythons b'' syntax doesn't stand for binary, but bytes hence why b'0010101' doesn't work like you want.

Bytes accepts hex data as bytes by default, to do this, you need to format the hex data as b'\xFF\x04'. For example

byte_obj = bytes(b'\xFF\x04')

This can then be sent over pyserial. To do binary you'll need to use python int's construction methods, ie the int(number, base) method.

This is further explained here

but this can basically be done via

bin_to_int int('01010101', 2)
byte_obj = bytes([bin_to_int]) #requires array of ints

Unfortunately that only works for binary strings of size 8 bits (and it will give you an error telling you so). In order to get around this, you can do the following:

bin_to_int int('0101010101010101', 2)
# to_bytes takes size in bytes and endianess, which is the order the bytes are placed.
byte_obj = bin_to_int.to_bytes(2, 'little')

little endian is least significant byte in smallest address (ie index 0) big is opposite

Be careful of the larger binary integer method, I'm not sure what python does internally to convert binary to an integer, but for arbitarily large binary data I would suspect slow down due to how I would niavely implement the conversion. I'll give you an example of why in how I would do the binary to unsigned integer conversion:

bit_string = "101010101..."
exponent = 0
decimal_value = 0
for bit in bit_string:
    decimal_value += int(bit)**exponent
    exponent += 1

It might not be quite obvious at first, but because python ints are arbitraily sized eventually you are going to get to the point where you are adding very large ints together, outside of typical arithmetic int size (ie larger than 64 bits). This means that over time with large binary values (which you will likely produce) you are going to get non linear time complexity as N increases the size in bytes of the additions will as well as they grow outside of 64 bits (and more processing will need to be done to carry out the addition, which will be O(n_bytes)) instead of O(1))

To solve this you would just need to make a function that separates the binary values before converting to bytes with them (like binary_to_bytes(binary_string))



来源:https://stackoverflow.com/questions/43729606/writing-bytes-out

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!