Форум программистов, компьютерный форум, киберфорум
Matlab
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.77/13: Рейтинг темы: голосов - 13, средняя оценка - 4.77
0 / 0 / 0
Регистрация: 05.11.2014
Сообщений: 25

Как работать с массивом cell array (сортировать и искать количество нужных элементов)

29.08.2016, 11:11. Показов 2970. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, уважаемые форумчане!
Помогите пожалуйста разобраться как искать сумму нужных элементов в массиве cell.
я экспортирую данные из excell MatLab как массив cell array обозначаю его буквой
Matlab M
1
 a
потом хочу посчитать количество элементов в 6 столбце как
Matlab M
1
2
f=sum(a(:,6)==0.25);
disp(f);
а Matlab ругается и говорит:
Undefined function 'eq' for input arguments of type 'cell'

скажи пожалуйста как мне посчитать количество нужных элементов в соответствующем столбце так чтобы я потом смог модифицировать программу и считал кол-во элементов таких где соответствующих строках нужных столбцов будет выбранное значение
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.08.2016, 11:11
Ответы с готовыми решениями:

Работать с массивом, как с набором различных по типу элементов
Посидел, пытался как-то перевести BYTE в wchar_t. Но так и не смог.. Не знаю, как даже сделать перевод. Помогите пожалуйста. ...

Как передать количество элементов List<> в Array[]
public Image itemImage = new Image; public Item item = new Item; List&lt;Item&gt; itemInInventar; public const int numItemSlots =...

Работа с массивом ячеек cell
Доброго времени суток. возникла необходимость поработать с бинарными числами разной длины, а так как сделать это, не изменив размер числа...

12
35 / 32 / 20
Регистрация: 26.02.2013
Сообщений: 184
29.08.2016, 12:20
Не совсем понял, что вы хотите сделать, но я при работе с excel файлами всегда сохраняю их в формате csv-файла, после можно применить команду
Matlab M
1
A = load('data.csv');
а затем работать с переменной А как с обычным массивом.
0
0 / 0 / 0
Регистрация: 05.11.2014
Сообщений: 25
29.08.2016, 12:25  [ТС]
я хочу применять оператор "==" для загруженного массива для того чтобы считать количество нужных элементов в нужном столбце
0
35 / 32 / 20
Регистрация: 26.02.2013
Сообщений: 184
29.08.2016, 12:31
ну так загрузите его как я рассказал, а потом смело можно применять
Цитата Сообщение от Boroguss Посмотреть сообщение
потом хочу посчитать количество элементов в 6 столбце как

Matlab M
1
2
 f=sum(a(:,6)==0.25);
 disp(f);
0
0 / 0 / 0
Регистрация: 05.11.2014
Сообщений: 25
29.08.2016, 12:35  [ТС]
VADIM290692, большое спасибо!
пытаюсь загрузить, но MatLab говорит

Error using load
Number of columns on line 2 of ASCII file c:\data.csv must be the same as previous
lines.
0
35 / 32 / 20
Регистрация: 26.02.2013
Сообщений: 184
29.08.2016, 12:45
у вас наверное десятичные дроби запятыми разделены? нужно на точки разделители поменять
0
0 / 0 / 0
Регистрация: 05.11.2014
Сообщений: 25
29.08.2016, 12:51  [ТС]
Увы, даже с точками всё равно сообщения об ошибках:
Matlab M
1
bb=load('data.csv');
Error using load
Number of columns on line 65 of ASCII file c:\data.csv must be the same as previous
lines.
0
35 / 32 / 20
Регистрация: 26.02.2013
Сообщений: 184
29.08.2016, 12:52
просто это можно сделать так Инструмент Найти и заменить в Excel

Добавлено через 1 минуту
прикрепите Ваш файл
0
0 / 0 / 0
Регистрация: 05.11.2014
Сообщений: 25
29.08.2016, 12:54  [ТС]
спасибо, я заменил запятые на точки,
Увы, даже с точками всё равно сообщения об ошибках:
Matlab M
Выделить код


bb=load('data.csv');

Error using load
Number of columns on line 65 of ASCII file c:\data.csv must be the same as previous
lines.
посмотрите пожалуйста.
Вложения
Тип файла: xlsx data2.xlsx (22.2 Кб, 3 просмотров)
0
35 / 32 / 20
Регистрация: 26.02.2013
Сообщений: 184
29.08.2016, 13:10
а. там у вас не только числа, тогда так не выйдет, надо чет другое думать...
ну если в лоб, то можно по столбцам экспортировать в матлаб, а потом искать в нужном столбце, хотя можно наверное и как-то хитрее
0
0 / 0 / 0
Регистрация: 05.11.2014
Сообщений: 25
29.08.2016, 13:14  [ТС]
это всё в матлаб можно эскпортировать, как cell array, если установить в надстройках матлабовский тулбокс. Только если потом хочу посчитать количество элементов в 6 столбце как
Matlab M
1
2
f=sum(a(:,6)==0.25);
disp(f);
Matlab ругается и говорит:
Undefined function 'eq' for input arguments of type 'cell'
0
370 / 133 / 44
Регистрация: 05.02.2015
Сообщений: 901
04.09.2016, 18:55
вашу проблему можно решить, например, так:
Matlab M
1
2
3
4
5
6
7
a = {1 2 3 4 5 6 7 8 10 25} % ячеечный массив, который вы экспортом получаете
s = 0; 
for i =1:length(a)
if isnumeric(a{i}) ==1; % сами пишем сумму
s = s + a{i};
end;
end;
Добавлено через 12 минут
а лучше даже так: допустим есть уже массив a:
Matlab M
1
2
3
4
5
b =[];
b = [b a{1:end}]; % если вы уверены, что в существующим столбце только числа
% сортируем считаем сумму, 
c = sort(b);
d = summ(b);
0
Эксперт по математике/физике
 Аватар для SSC
3390 / 1913 / 571
Регистрация: 09.04.2015
Сообщений: 5,365
05.09.2016, 15:13
Boroguss, у Вас какая-то ошибка с форматом данных чисел с плавающей запятой в файле.
Я загрузил файл в MATLAB и данные из столбца G считались как NaN/
После этого в ячейках G1:G15 ставил курсор ввода в конец Ваших данных и нажимал Enter. Сохранил файл и программа с измененными данными стала работать.
Текст программы
Matlab M
1
2
3
clc, clear all
[aNumb, aText ] = xlsread('data2.xlsx',1,'A1:V128');
f=sum(aNumb(:,6)==0.25);
Добавлено через 10 минут
Сохранил Ваш файл в csv формате.
Заново открыл в EXCEL и сохранил в xlsx формате и данные стали читаться.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.09.2016, 15:13
Помогаю со студенческими работами здесь

Как работать с классом Array?
Подскажите, как работать с классом Array.

Как записать в переменную Array элемент массива, который в свою очередь так же является массивом
Вот часть кода. Array sim = new Array; for (int i = 0; i &lt;= slova.Length - 1; i++) { if...

Сортировать массив модифицированным пузырьком с помощью функции, заранее не зная количество элементов
Нужно сортировать массив модифицированным пузырьком с помощью функции, заранее не зная количество элементов. Плохо дружу с указателями и...

Как работать с двумерным массивом?
Есть такой вот массив: int ary = { { 1, 2, 3, 4, 5 }, { 2, 4, 6, 8, 10 }, { 3, 6, 9, 12, 15 } Здесь 3 строки и 5...

Как работать с массивом на PHP?
У меня есть запрос от API VK, который возвращает id всех друзей пользователя. Мне нужно каждый id выводить на новой строке, помогите...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru