У меня есть одна программа, написанная на C++, которая выводит данные из нескольких разных типов массивов. Для простоты я использую целые числа и просто пишу их по одному, чтобы понять это.
Мне нужно иметь возможность прочитать файл на Python, но я явно что-то упускаю. У меня возникли проблемы с переводом концепций с C++ на Python.
Это работающий у меня С++ - он записывает два числа в файл, а затем считывает этот файл обратно (да, я должен использовать функции ostream.write() и istream.read() - вот как в основе level библиотека, которую я использую, делает это, и я не могу это изменить).
int main(int argc, char **argv) {
std::ofstream fout;
std::ifstream fin;
int outval1 = 1234;
int outval2 = 5678;
fout.open("out.txt");
fout.write(reinterpret_cast<const char*>(&outval1), sizeof(int));
fout.write(reinterpret_cast<const char*>(&outval2), sizeof(int));
fout.close();
int inval;
fin.open("out.txt");
while (fin.read(reinterpret_cast<char*>(&inval), sizeof(int))) {
std::cout << inval << std::endl;
}
fin.close();
return 0;
}
Это то, что у меня есть на стороне Python, но я знаю, что это неправильно. Я не думаю, что мне нужно читать как двоичный код, но это единственный способ, которым он работает до сих пор.
with open("out.txt", "rb") as f:
while (byte := f.read(1)):
print(byte)
Эти файлы reinterpret_cast, write и read кажутся мне очень подозрительными. Вы лжете и говорите, что &outval1 является указателем на const char, и предлагаете написать первые sizeof(int) многие const char из «массива», на который указывает. Что, я полагаю, приводит к написанию двоичного представления int. Но... действительно, почему вы делаете это именно так?
Вы должны открывать файлы в двоичном режиме в этом коде. Это необходимо, чтобы избежать повреждения, если вы планируете запускать свою программу в Windows, и просто хорошая практика, чтобы показать намерение на других платформах, где это не имеет большого значения.
@NathanPierson именно так написана библиотека. Он предназначен для приема нескольких различных типов значений из массива, подобного структуре, и их записи. Я полагаю, это было написано так, чтобы сохранить гибкость. я не мог сказать






В приведенном вами простом случае легко написать код Python для считывания 1234 и 5678 (при условии, что sizeof(int) составляет 4 байта), используя int.from_bytes.
И вы должны открыть файл в двоичном режиме.
import sys
with open("out.txt", "rb") as f:
while (byte := f.read(4)):
print(int.from_bytes(byte, sys.byteorder))
Чтобы справиться с поплавками, вы можете попробовать struct.unpack:
import struct
byte = f.read(4)
print(struct.unpack("f", byte)[0])
В итоге это сработало для меня. Единственное, что мне сейчас интересно, это как сделать то же самое для поплавков (выход из С++)
@dave, вы можете взглянуть на структуру
Если вы хотите записать файл в виде текста, возможно, используйте
itoa()или даже простоfprintf? Затем вы можете прочитать его как текст на стороне Python.