Считайте данные ASCII из устройства и отформатируйте как текст
A = fscanf (obj)
A = fscanf (obj, 'format')
A = fscanf (obj, 'format', размер)
[A, количество] = fscanf (...)
[A, количество, сообщение] = fscanf (...)
A = fscanf(obj) считывает данные ASCII из устройства, соединенного к объекту последовательного порта, obj, и возвращает его в A. Данные преобразованы в текст с помощью формата %c. Для двоичных данных используйте fread.
считывает данные и преобразовывает его согласно A = fscanf(obj,'format')format. format является спецификацией преобразования языка C. Спецификации преобразования включают символ % и символы преобразования d, i, o, u, x, X, f, e, E, g, G, c, и s. Обратитесь к спецификациям формата файлового ввода-вывода sscanf или руководству C для получения дополнительной информации.
читает количество значений, заданных A = fscanf(obj,'format',size)size. Допустимые опции для size:
| Читайте в большинстве значений |
| Читайте в большинстве значений m на n, заполняющих матрицу m на n в порядке следования столбцов. |
size не может быть inf, и ошибка возвращена, если конкретное количество значений не может быть сохранено во входном буфере. Если size не имеет формы [m,n], и преобразование символов задано, то A возвращен как вектор - строка. Вы задаете размер, в байтах, входного буфера со свойством InputBufferSize. Значение ASCII составляет один байт.
[A,count] = fscanf(...) возвращает количество чтения значений к count.
[A,count,msg] = fscanf(...) возвращает предупреждающее сообщение в msg, если операция чтения не завершалась успешно.
Создайте объект последовательного порта s и соедините s с осциллографом Tektronix® TDS 210, который отображает синусоиду. Этот пример работает на платформе Windows®.
s = serial('COM1');
fopen(s)
Используйте функцию fprintf, чтобы сконфигурировать осциллограф, чтобы измерить напряжение от пика к пику синусоиды, возвратить тип измерения и возвратить напряжение от пика к пику.
fprintf(s,'MEASUREMENT:IMMED:TYPE PK2PK') fprintf(s,'MEASUREMENT:IMMED:TYPE?') fprintf(s,'MEASUREMENT:IMMED:VALUE?')
Поскольку значением по умолчанию для свойства ReadAsyncMode является continuous, данные, сопоставленные с этими двумя командами запроса, автоматически возвращен во входной буфер.
s.BytesAvailable
ans =
21
Используйте fscanf, чтобы считать тип измерения. Операция завершится, когда первый терминатор строки будет считан.
meas = fscanf(s)
meas = PK2PK
Используйте fscanf, чтобы считать напряжение от пика к пику как число с плавающей запятой и исключить терминатор строки.
pk2pk = fscanf(s,'%e',14)
pk2pk =
2.0200
Отключите s от осциллографа и удалите s из памяти и рабочей области.
fclose(s) delete(s) clear s
Прежде чем можно будет считать данные из устройства, оно должно быть соединено с obj с функцией fopen. Связанный объект последовательного порта имеет значение свойства Status open. Ошибка возвращена, при попытке выполнить операцию чтения, в то время как obj не соединяется с устройством.
Если msg не включен как выходной аргумент, и операция чтения не была успешна, то предупреждающее сообщение возвращено в командную строку.
Значение свойства ValuesReceived увеличено количеством чтения значений – включая терминатор строки – каждый раз, когда fscanf выпущен.
Операция чтения с fscanf блокирует доступ к командной строке MATLAB® до:
Считался терминатор строки, заданный как свойство Terminator.
Прошло время, заданное как свойство Timeout.
Считалось количество значений, заданных в size.
Входной буфер заполнен (если size не задан),
BytesAvailable | BytesAvailableFcn | InputBufferSize | Состояние | Терминатор | Тайм-аут | fgetl | fgets | fopen | fread | textscan