It turns out that in Python 3, attempting to write non-ASCII characters to a file without using ‘binary mode’ (a mode which deals with ’non-textual data’, hence the name of the challenge) has some less-than-ideal results. Indeed, if you tried providing your plain text to xor.py you might have noticed that there are somehow more bytes in the cypher-text after XORing that you started with in your plaintext. Ultimately, it appears that the write.write(ciphertext) function is prepending either 0xc2 or 0xc3 to certain bytes. Simply adding a condition to exclude these, and providing the cipher-text as the input (since XOR is the inverse of itself) will provide a simple solution to this puzzle.

from random import seed, randrange


seed(True, version=2)

with open("plaintext.txt", 'r') as read, open("ciphertext.txt", 'w') as write:
    plaintext = read.read()

    for char in plaintext:
        A = ord(char)
        if A != 194 and A != 195:  # exclude 0xc2 and 0xc3
            B = randrange(256)
            ciphertext = chr(A ^ B)
            print(bytes([A ^ B]))
            write.write(ciphertext)

Flag: UACTF{b4d_h4b175_l34d_70_py7h0n2}