如何在排序时按名称引用此表列?

时间:2017-10-13 22:30:10

标签: excel excel-vba vba

第三行错误输出错误5,无效的过程调用或参数。

tbl.Range("Table[Matter ID]")

我知道问题是tbl.Range.Cells(8)我已经使用?tbl.Range.Address修复了它并且它有效。但为什么不是第一个工作?

我可以去?tbl.Range.Resize(1).Address并获得有效的范围地址。

我可以去{{1}}并获得有效的范围地址。

名称“表格”和“物质ID”是正确的。 Excel表(ListObjects)的一个优点是您可以按名称引用列。我做错了什么?

1 个答案:

答案 0 :(得分:2)

在tbl中没有范围("表[事项ID]和#34;)但是在tbl.parent中有一个范围("表[事项ID]")。 / p>

void computeFFTMag(Mat&,Mat&,Mat&);
string getImgType(int );

int main( int argc, char** argv )
{
    Mat ref,sens,refMag,sensMag,refFFT,sensFFT;
    ref = imread("lena1.jpg",CV_LOAD_IMAGE_GRAYSCALE);
    sens = imread("lena3.jpg",CV_LOAD_IMAGE_GRAYSCALE);


    namedWindow( "Sensed Image", CV_WINDOW_AUTOSIZE );
    imshow( "Sensed Image", sens );

    computeFFTMag(ref,refMag,refFFT);
    computeFFTMag(sens,sensMag,sensFFT);


    Mat R1,R2,R,r,rf[2],rff;
    mulSpectrums(refFFT,sensFFT,R1,0,true);
    multiply(refMag,sensMag,R2);
    dft(R1,r,DFT_REAL_OUTPUT);
    split(r,rf);
    divide(rf[0],R2,r);
    normalize(r, r, 0, 1, CV_MINMAX);
    namedWindow( "Reference Image", CV_WINDOW_AUTOSIZE );
    imshow("Reference Image"       , r   );
}



void computeFFTMag(Mat& input,Mat& fftMag,Mat& complexFFT){
    Mat inputPadded;
    /*int r=getOptimalDFTSize(input.rows);
    int c=getOptimalDFTSize(input.cols);
    copyMakeBorder(input,inputPadded,0,r-input.rows,0,c-input.cols,BORDER_CONSTANT, Scalar::all(0));*/
    Mat fftPlanes[] = {Mat_<float>(input), Mat::zeros(input.size(), CV_32F)};
    //Mat complexFFT;
    merge(fftPlanes, 2, complexFFT);

    dft(complexFFT,complexFFT);
    split(complexFFT,fftPlanes);
    magnitude(fftPlanes[0],fftPlanes[1],fftPlanes[0]);

    fftMag=fftPlanes[0];

    //fftMag = fftMag(Rect(0, 0, fftMag.cols & -2, fftMag.rows & -2));
    int cx = fftMag.cols/2;
    int cy = fftMag.rows/2;
    Mat q0(fftMag, Rect(0, 0, cx, cy));   // Top-Left - Create a ROI per quadrant
    Mat q1(fftMag, Rect(cx, 0, cx, cy));  // Top-Right
    Mat q2(fftMag, Rect(0, cy, cx, cy));  // Bottom-Left
    Mat q3(fftMag, Rect(cx, cy, cx, cy)); // Bottom-Right

    Mat tmp;                           // swap quadrants (Top-Left with Bottom-Right)
    q0.copyTo(tmp);
    q3.copyTo(q0);
    tmp.copyTo(q3);

    q1.copyTo(tmp);                    // swap quadrant (Top-Right with Bottom-Left)
    q2.copyTo(q1);
    tmp.copyTo(q2);
}

范围(&#34;表[事项ID]&#34;)是表所在工作表的子项,而不是表的子项。

enter image description here