다음을 통해 공유


방법: 워크시트에 NamedRange 컨트롤 추가

디자인 타임 및 런타임에 문서 수준 프로젝트에서 Microsoft Office Excel 워크시트에 NamedRange 컨트롤을 추가할 수 있습니다.

적용 대상: 이 항목의 정보는 Excel 2007 및 Excel 2010의 문서 수준 프로젝트 및 응용 프로그램 수준 프로젝트에 적용됩니다. 자세한 내용은 Office 응용 프로그램 및 프로젝트 형식에 따라 사용 가능한 기능을 참조하십시오.

런타임에 응용 프로그램 수준 프로젝트에서도 NamedRange 컨트롤을 추가할 수 있습니다.

이 항목에서는 다음 작업에 대해 설명합니다.

  • 디자인 타임에 NamedRange 컨트롤 추가

  • 런타임에 문서 수준 프로젝트에서 NamedRange 컨트롤 추가

  • 런타임에 응용 프로그램 수준 프로젝트에서 NamedRange 컨트롤 추가

NamedRange 컨트롤에 대한 자세한 내용은 NamedRange 컨트롤을 참조하십시오.

디자인 타임에 NamedRange 컨트롤 추가

디자인 타임에 Excel, Visual Studio 도구 상자데이터 소스 창에서 여러 가지 방법으로 문서 수준 프로젝트의 워크시트에 NamedRange 컨트롤을 추가할 수 있습니다.

참고

다음 지침처럼 컴퓨터에서 Visual Studio 사용자 인터페이스 요소 일부에 대한 이름이나 위치를 다르게 표시할 수 있습니다. 이러한 요소는 사용하는 Visual Studio 버전 및 설정에 따라 결정됩니다. 자세한 내용은 Visual Studio 설정을 참조하십시오.

Excel에서 이름 상자를 사용하여 워크시트에 NamedRange 컨트롤을 추가하려면

  1. 명명된 범위에 포함시킬 셀을 하나 이상 선택합니다.

  2. 이름 상자에 범위의 이름을 입력하고 Enter 키를 누릅니다.

    이름 상자는 수식 입력줄 옆에 워크시트의 A 열 바로 위에 있습니다.

도구 상자를 사용하여 워크시트에 NamedRange 컨트롤을 추가하려면

  1. 도구 상자를 열고 Excel 컨트롤 탭을 클릭합니다.

  2. NamedRange를 클릭하여 워크시트에 끌어 놓습니다.

    NamedRange 컨트롤 추가 대화 상자가 표시됩니다.

  3. 명명된 범위에 포함시킬 셀을 하나 이상 선택합니다.

  4. 확인을 클릭합니다.

    컨트롤에 기본적으로 지정된 이름을 사용하지 않으려면 속성 창에서 이름을 변경합니다.

데이터 소스 창을 사용하여 워크시트에 NamedRange 컨트롤을 추가하려면

  1. 데이터 소스 창을 열고 프로젝트의 데이터 소스를 만듭니다. 자세한 내용은 방법: 데이터베이스의 데이터에 연결를 참조하십시오.

  2. 데이터 소스 창의 단일 필드를 워크시트로 끌어 옵니다.

    데이터 바인딩된 NamedRange 컨트롤이 워크시트에 추가됩니다. 자세한 내용은 데이터 바인딩 및 Windows Forms을 참조하십시오.

런타임에 문서 수준 프로젝트에서 NamedRange 컨트롤 추가

런타임에 NamedRange 컨트롤을 워크시트에 프로그래밍 방식으로 추가할 수 있습니다. 이렇게 하면 이벤트에 대한 응답으로 호스트 컨트롤을 만들 수 있습니다. 동적으로 만들어진 명명된 범위는 워크시트를 닫을 때 워크시트에 호스트 컨트롤로 유지되지 않습니다. 자세한 내용은 런타임에 Office 문서에 컨트롤 추가를 참조하십시오.

프로그래밍 방식으로 워크시트에 NamedRange 컨트롤을 추가하려면

  • Sheet1의 Startup 이벤트 처리기에서 다음 코드를 삽입하여 A1 셀에 NamedRange 컨트롤을 추가하고 해당 Value2 속성을 Hello world!로 설정합니다.

    Dim textInCell As Microsoft.Office.Tools.Excel.NamedRange
    textInCell = Me.Controls.AddNamedRange(Me.Range("A1"), "cellText")
    
    textInCell.Value2 = "Hello world!"
    
    Microsoft.Office.Tools.Excel.NamedRange textInCell;
    textInCell = this.Controls.AddNamedRange(this.get_Range("A1", missing), "cellText");
    
    textInCell.Value2 = "Hello world!";
    

런타임에 응용 프로그램 수준 프로젝트에서 NamedRange 컨트롤 추가

응용 프로그램 수준 프로젝트에서 열려 있는 워크시트에 NamedRange 컨트롤을 프로그래밍 방식으로 추가할 수 있습니다. 동적으로 만들어진 명명된 범위는 워크시트를 닫을 때 워크시트에 호스트 컨트롤로 유지되지 않습니다. 자세한 내용은 런타임에 응용 프로그램 수준 추가 기능의 Word 문서 및 Excel 통합 문서 확장을 참조하십시오.

프로그래밍 방식으로 워크시트에 NamedRange 컨트롤을 추가하려면

  • 다음 코드에서는 열려 있는 워크시트를 기반으로 하는 워크시트 호스트 항목을 생성한 다음 A1 셀에 NamedRange 컨트롤을 추가하고 해당 Value2 속성을 Hello world로 설정합니다.

    Private Sub AddNamedRange()
        Dim textInCell As Microsoft.Office.Tools.Excel.NamedRange
    
        Dim NativeWorksheet As Microsoft.Office.Interop.Excel.Worksheet =
            Globals.ThisAddIn.Application.ActiveWorkbook.Worksheets(1)
    
        ' Use the following line of code in projects that target the .NET Framework 4.
        Dim worksheet As Microsoft.Office.Tools.Excel.Worksheet =
            Globals.Factory.GetVstoObject(NativeWorksheet)
    
        ' In projects that target the .NET Framework 3.5, use the following line of code.
        ' Dim worksheet = CType(Globals.ThisAddIn.Application.ActiveWorkbook.Worksheets(1),  _
        '    Excel.Worksheet).GetVstoObject()
    
        Dim cell As Excel.Range = worksheet.Range("A1")
        textInCell = worksheet.Controls.AddNamedRange(cell, "MyNamedRange")
        textInCell.Value2 = "Hello World"
    End Sub
    
    private void AddNamedRange()
    {
        Microsoft.Office.Tools.Excel.NamedRange textInCell;
    
        // Use the following line of code in projects that target the .NET Framework 4.
        Worksheet worksheet = Globals.Factory.GetVstoObject(
            Globals.ThisAddIn.Application.ActiveWorkbook.Worksheets[1]);
    
        // In projects that target the .NET Framework 3.5, use the following line of code.
        // Worksheet worksheet = 
        //     ((Excel.Worksheet)Globals.ThisAddIn.Application.ActiveWorkbook.Worksheets[1]).GetVstoObject();
    
        Excel.Range cell = worksheet.Range["A1", missing]; 
        textInCell = worksheet.Controls.AddNamedRange(cell, "MyNamedRange");
        textInCell.Value2 = "Hello World";
     }
    

참고 항목

작업

방법: NamedRange 컨트롤 크기 조정

개념

런타임에 응용 프로그램 수준 추가 기능의 Word 문서 및 Excel 통합 문서 확장

NamedRange 컨트롤

확장된 개체를 사용하여 Excel 자동화

호스트 항목 및 호스트 컨트롤 개요

호스트 항목 및 호스트 컨트롤의 프로그래밍에 대한 제한 사항

기타 리소스

Office 문서의 컨트롤