通过python在matlab中保存.mat文件

时间:2014-05-21 20:06:31

标签: python matlab file-io

当我直接运行demo.m时,来自demo.m的这一行在MatLab中运行良好:

save('C:\PATH_TO_MY_FOLDER\boxes.mat', 'boxes');

因此,当我检查文件夹时,我确实发现已经创建了一个名为boxes.mat的文件,该文件包含一个2D数组。

然而,当我从python运行demo.m时(在下面的代码中),Matlab似乎打开了,但boxes.mat似乎没有得到保存。

import win32com.client
h = win32com.client.Dispatch('matlab.application')
h.Execute ("C:\\PATH_TO_MY_FOLDER\\demo.m")

我可能在第一时间没有成功运行demo.m吗? 我添加了一行

fprintf('hello'); 
保存demo.m文件的行之前的boxes.mat中的

,但也没有获得该输出。 我怎样才能确定demo.m甚至是从Python执行的?我确实看到Matlab按钮出现在任务栏中片刻。

demo.m的代码略有编辑,取自here

% This demo shows how to use the software described in our IJCV paper: 
%   Selective Search for Object Recognition,
%   J.R.R. Uijlings, K.E.A. van de Sande, T. Gevers, A.W.M. Smeulders, IJCV 2013
%%
addpath('Dependencies');

fprintf('Demo of how to run the code for:\n');
fprintf('   J. Uijlings, K. van de Sande, T. Gevers, A. Smeulders\n');
fprintf('   Segmentation as Selective Search for Object Recognition\n');
fprintf('   IJCV 2013\n\n');

% Compile anisotropic gaussian filter
if(~exist('anigauss'))
    fprintf('Compiling the anisotropic gauss filtering of:\n');
    fprintf('   J. Geusebroek, A. Smeulders, and J. van de Weijer\n');
    fprintf('   Fast anisotropic gauss filtering\n');
    fprintf('   IEEE Transactions on Image Processing, 2003\n');
    fprintf('Source code/Project page:\n');
    fprintf('   http://staff.science.uva.nl/~mark/downloads.html#anigauss\n\n');
    mex Dependencies/anigaussm/anigauss_mex.c Dependencies/anigaussm/anigauss.c -output anigauss
end

if(~exist('mexCountWordsIndex'))
    mex Dependencies/mexCountWordsIndex.cpp
end

% Compile the code of Felzenszwalb and Huttenlocher, IJCV 2004.
if(~exist('mexFelzenSegmentIndex'))
    fprintf('Compiling the segmentation algorithm of:\n');
    fprintf('   P. Felzenszwalb and D. Huttenlocher\n');
    fprintf('   Efficient Graph-Based Image Segmentation\n');
    fprintf('   International Journal of Computer Vision, 2004\n');
    fprintf('Source code/Project page:\n');
    fprintf('   http://www.cs.brown.edu/~pff/segment/\n');
    fprintf('Note: A small Matlab wrapper was made.\n');
%     fprintf('   
    mex Dependencies/FelzenSegment/mexFelzenSegmentIndex.cpp -output mexFelzenSegmentIndex;
end

%%
% Parameters. Note that this controls the number of hierarchical
% segmentations which are combined.
colorTypes = {'Hsv', 'Lab', 'RGI', 'H', 'Intensity'};
colorType = colorTypes{1}; % Single color space for demo

% Here you specify which similarity functions to use in merging
simFunctionHandles = {@SSSimColourTextureSizeFillOrig, @SSSimTextureSizeFill, @SSSimBoxFillOrig, @SSSimSize};
simFunctionHandles = simFunctionHandles(1:2); % Two different merging strategies

% Thresholds for the Felzenszwalb and Huttenlocher segmentation algorithm.
% Note that by default, we set minSize = k, and sigma = 0.8.
k = 200; % controls size of segments of initial segmentation. 
minSize = k;
sigma = 0.8;

% As an example, use a single image
images = {'000016.jpg'};
%images = {'C:\Users\Public\Pictures\Sample Pictures\Desert.jpg'};
im = imread(images{1});

% Perform Selective Search
[boxes blobIndIm blobBoxes hierarchy] = Image2HierarchicalGrouping(im, sigma, k, minSize, colorType, simFunctionHandles);
boxes = BoxRemoveDuplicates(boxes);

save('C:\work_asaaki\code\SelectiveSearchCodeIJCV\boxes.mat', 'boxes');

1 个答案:

答案 0 :(得分:1)

您要求Matlab运行命令' C:\ PATH_TO_MY_FOLDER \ demo.m',这不是有效的matlab命令,如果您将其输入matlab控制台,您将收到相同的错误消息

你可能想要的是:

h.Execute ("cd('C:\\PATH_TO_MY_FOLDER');")
h.Execute ("demo;")

这是您在matlab中所做的,更改目录然后运行它。您也可以使用run创建一行,但由于脚本中的相对路径,这可能不起作用。