Jak kopiować komórki za pomocą IronXL

Jak kopiować komórki w języku C# za pomocą IronXL

This article was translated from English: Does it need improvement?
Translated
View the article in English

IronXL umożliwia kopiowanie komórek, zakresów, wierszy lub kolumn w arkuszach Excel za pomocą jednej metody Copy, która zachowuje całe formatowanie i stylizacje, w tym samym czasie duplikując dane między dowolnymi lokalizacjami lub arkuszami.

Funkcja "Kopiuj komórkę" powiela zawartość komórki i wkleja ją do innych komórek. Replikuje dane, formuły, formatowanie i inne atrybuty w arkuszu. Whether creating spreadsheets from scratch or loading existing Excel files, the copy functionality is essential for efficient data manipulation.

Szybki start: Kopiowanie kolumny lub zakresu w jednym wierszu

Kopiuj całe zakresy — pojedyncze komórki, wiersze, kolumny lub bloki — z jednego arkusza do drugiego za pomocą jednego wywołania metody. Funkcja Copy zachowuje stylizacje i formatowanie, czyniąc automatyzację Excel szybką i prostą.

  1. Install IronXL with NuGet Package Manager

    PM > Install-Package IronXl.Excel
  2. Skopiuj i uruchom ten fragment kodu.

    workSheet.GetColumn(0).Copy(workBook.GetWorkSheet("Sheet1"), "H1");
  3. Wdrożenie do testowania w środowisku produkcyjnym

    Rozpocznij używanie IronXL w swoim projekcie już dziś z darmową wersją próbną

    arrow pointer


Jak skopiować pojedynczą komórkę w programie Excel?

Aby skopiować zawartość wybranej komórki, użyj metody Copy. Przekaż obiekt arkusza jako pierwszy parametr, a pozycję początkową jako drugi parametr. The Copy method retains all styling including font and size, background patterns and colors, and borders and alignment.

:path=/static-assets/excel/content-code-examples/how-to/copy-cells-copy-single-cell.cs
using IronXL;

WorkBook workBook = WorkBook.Load("sample.xlsx");
WorkSheet workSheet = workBook.GetWorkSheet("Sheet1");

// Copy cell content
workSheet["A1"].Copy(workBook.GetWorkSheet("Sheet1"), "B3");

workBook.SaveAs("copySingleCell.xlsx");
using IronXL;

WorkBook workBook = WorkBook.Load("sample.xlsx");
WorkSheet workSheet = workBook.GetWorkSheet("Sheet1");

// Copy cell content
workSheet["A1"].Copy(workBook.GetWorkSheet("Sheet1"), "B3");

workBook.SaveAs("copySingleCell.xlsx");
using IronXL;

WorkBook workBook = WorkBook.Load("sample.xlsx");
WorkSheet workSheet = workBook.GetWorkSheet("Sheet1");

// Copy cell content
workSheet["A1"].Copy(workBook.GetWorkSheet("Sheet1"), "B3");

workBook.SaveAs("copySingleCell.xlsx");
Imports IronXL

Dim workBook As WorkBook = WorkBook.Load("sample.xlsx")
Dim workSheet As WorkSheet = workBook.GetWorkSheet("Sheet1")

' Copy cell content
workSheet("A1").Copy(workBook.GetWorkSheet("Sheet1"), "B3")

workBook.SaveAs("copySingleCell.xlsx")
$vbLabelText   $csharpLabel

Jakie formatowanie jest zachowywane podczas kopiowania?

Metoda Copy zachowuje wszystkie właściwości komórki, w tym:

  • wartości i formuły Cell
  • Formaty liczb (waluta, procenty, daty)
  • Styl czcionki (krój, rozmiar, pogrubienie, kursywa, kolor)
  • Obramowania komórek i kolory tła
  • Wyrównanie tekstu (poziome i pionowe)
  • Ustawienia ochrony komórek

Ta kompleksowa ochrona gwarantuje, że skopiowane komórki zachowują swój pierwotny wygląd i funkcjonalność, podobnie jak przy użyciu skrótów klawiszowych Ctrl+C i Ctrl+V w programie Microsoft Excel.

Arkusz kalkulacyjny pokazujący zaznaczoną komórkę A1 ze strzałką wskazującą komórkę B3 zawierającą skopiowaną wartość, demonstrujący kopiowanie pojedynczej komórki

Dlaczego metoda Copy przyjmuje dwa parametry?

Metoda Copy wymaga dwóch parametrów dla dokładnej kontroli:

  1. Parametr arkusza: Określa arkusz docelowy (ten sam lub inny w ramach skoroszytu)
  2. Parametr adresu: Określa pozycję komórki początkowej dla wklejanej treści

Taki układ pozwala na elastyczne kopiowanie w obrębie tego samego arkusza lub między różnymi arkuszami, co idealnie nadaje się do tworzenia raportów podsumowujących lub konsolidacji danych z wielu źródeł.

Kiedy należy używać kopiowania pojedynczej komórki, a kiedy kopiowania zakresu?

Wybierz opcję kopiowania pojedynczej komórki, gdy:

  • Powielanie poszczególnych wartości lub formuł
  • Kopiowanie komórek nagłówkowych lub etykiet
  • Odwzorowanie konkretnych wyników obliczeń
  • Praca z wartościami podsumowującymi

Użyj stylu "range copy", gdy:

  • Przenoszenie całych tabel danych
  • Duplikowanie wielu powiązanych komórek
  • Kopiowanie całych wierszy lub kolumn
  • Zachowanie relacji między danymi

Jak skopiować wiele komórek lub zakresów?

Like the Clear method, Copy is available in the Range class, allowing execution on any range size. When selecting ranges, IronXL provides flexible copying options:

  • Skopiuj pojedynczą komórkę (C10):

    workSheet["C10"].Copy(workBook.GetWorkSheet("Sheet1"), "B13");
    workSheet["C10"].Copy(workBook.GetWorkSheet("Sheet1"), "B13");
    workSheet("C10").Copy(workBook.GetWorkSheet("Sheet1"), "B13")
    $vbLabelText   $csharpLabel
  • Skopiuj kolumne (A):

    workSheet.GetColumn(0).Copy(workBook.GetWorkSheet("Sheet1"), "H1");
    workSheet.GetColumn(0).Copy(workBook.GetWorkSheet("Sheet1"), "H1");
    workSheet.GetColumn(0).Copy(workBook.GetWorkSheet("Sheet1"), "H1")
    $vbLabelText   $csharpLabel
  • Skopiuj wiersz (4):

    workSheet.GetRow(3).Copy(workBook.GetWorkSheet("Sheet1"), "A15");
    workSheet.GetRow(3).Copy(workBook.GetWorkSheet("Sheet1"), "A15");
    workSheet.GetRow(3).Copy(workBook.GetWorkSheet("Sheet1"), "A15")
    $vbLabelText   $csharpLabel
  • Skopiuj zakres dwuwymiarowy (D6:F8):

    workSheet["D6:F8"].Copy(workBook.GetWorkSheet("Sheet1"), "H17");
    workSheet["D6:F8"].Copy(workBook.GetWorkSheet("Sheet1"), "H17");
    workSheet("D6:F8").Copy(workBook.GetWorkSheet("Sheet1"), "H17")
    $vbLabelText   $csharpLabel

Zwróć uwagęDrugi parametr przyjmuje adres lokalizacji, który wyznacza punkt początkowy wprowadzania danych. Skopiowane dane będą zaczynać się od tego adresu i rozciągać się w prawo i w dół.

:path=/static-assets/excel/content-code-examples/how-to/copy-cells-copy-cell-range.cs
using IronXL;

WorkBook workBook = WorkBook.Load("sample.xlsx");
WorkSheet workSheet = workBook.GetWorkSheet("Sheet1");

// Copy a single cell(C10)
workSheet["C10"].Copy(workBook.GetWorkSheet("Sheet1"), "B13");

// Copy a column(A)
workSheet.GetColumn(0).Copy(workBook.GetWorkSheet("Sheet1"), "H1");

// Copy a row(4)
workSheet.GetRow(3).Copy(workBook.GetWorkSheet("Sheet1"), "A15");

// Copy a two-dimensional range(D6:F8)
workSheet["D6:F8"].Copy(workBook.GetWorkSheet("Sheet1"), "H17");

workBook.SaveAs("copyCellRange.xlsx");
using IronXL;

WorkBook workBook = WorkBook.Load("sample.xlsx");
WorkSheet workSheet = workBook.GetWorkSheet("Sheet1");

// Copy a single cell(C10)
workSheet["C10"].Copy(workBook.GetWorkSheet("Sheet1"), "B13");

// Copy a column(A)
workSheet.GetColumn(0).Copy(workBook.GetWorkSheet("Sheet1"), "H1");

// Copy a row(4)
workSheet.GetRow(3).Copy(workBook.GetWorkSheet("Sheet1"), "A15");

// Copy a two-dimensional range(D6:F8)
workSheet["D6:F8"].Copy(workBook.GetWorkSheet("Sheet1"), "H17");

workBook.SaveAs("copyCellRange.xlsx");
using IronXL;

WorkBook workBook = WorkBook.Load("sample.xlsx");
WorkSheet workSheet = workBook.GetWorkSheet("Sheet1");

// Copy a single cell(C10)
workSheet["C10"].Copy(workBook.GetWorkSheet("Sheet1"), "B13");

// Copy a column(A)
workSheet.GetColumn(0).Copy(workBook.GetWorkSheet("Sheet1"), "H1");

// Copy a row(4)
workSheet.GetRow(3).Copy(workBook.GetWorkSheet("Sheet1"), "A15");

// Copy a two-dimensional range(D6:F8)
workSheet["D6:F8"].Copy(workBook.GetWorkSheet("Sheet1"), "H17");

workBook.SaveAs("copyCellRange.xlsx");
Imports IronXL

Dim workBook As WorkBook = WorkBook.Load("sample.xlsx")
Dim workSheet As WorkSheet = workBook.GetWorkSheet("Sheet1")

' Copy a single cell(C10)
workSheet("C10").Copy(workBook.GetWorkSheet("Sheet1"), "B13")

' Copy a column(A)
workSheet.GetColumn(0).Copy(workBook.GetWorkSheet("Sheet1"), "H1")

' Copy a row(4)
workSheet.GetRow(3).Copy(workBook.GetWorkSheet("Sheet1"), "A15")

' Copy a two-dimensional range(D6:F8)
workSheet("D6:F8").Copy(workBook.GetWorkSheet("Sheet1"), "H17")

workBook.SaveAs("copyCellRange.xlsx")
$vbLabelText   $csharpLabel

Co się dzieje, gdy zakres docelowy jest zbyt mały?

IronXL automatycznie radzi sobie z różnicami w rozmiarze:

  • Parametr docelowy określa tylko komórkę startową w lewym górnym rogu
  • Kopiowanie całego zakresu źródłowego niezależnie od rozmiaru docelowego
  • Istniejące dane w obszarze docelowym zostaną nadpisane
  • Operacja kopiowania rozszerza się, aby uwzględnić wszystkie dane źródłowe

Na przykład, kopiowanie zakresu 3x3 do komórki B1 wypełnia komórki B1:D3, nadpisując wszelkie istniejące treści.

Jak działają odwołania do wierszy i kolumn?

IronXL używa indeksowania opartego na zerach dla wierszy i kolumn z metodami GetRow() i GetColumn():

  • GetColumn(0) odnosi się do kolumny A
  • GetColumn(1) odnosi się do kolumny B
  • GetRow(0) odnosi się do wiersza 1
  • GetRow(3) odnosi się do wiersza 4

Indeksowanie jest zgodne ze standardowymi konwencjami dotyczącymi tablic w języku C#.

Dlaczego warto korzystać z metod GetColumn() i GetRow()?

Metody GetColumn() i GetRow() oferują:

  • Wydajność: większa wydajność w przypadku całych wierszy lub kolumn
  • Przejrzystość: sprawia, że intencja kodu jest bardziej zrozumiała
  • Elastyczność: Zwraca obiekt Range wspierający wszystkie operacje zakresu
  • Wygoda: nie ma potrzeby obliczania komórek końcowych dla pełnych zaznaczeń

Metody te sprawdzają się doskonale podczas tworzenia raportów wymagających pełnego kopiowania kolumn lub podczas powielania szablonów wierszy.

Operacje kopiowania w Excelu pokazujące strzałki od zakresów źródłowych A1:F10 do komórek docelowych z podświetlonymi skopiowanymi danymi

Jak skopiować komórki między różnymi arkuszami?

Pierwszy parametr przyjmuje obiekt arkusza, umożliwiając kopiowanie i wklejanie między różnymi arkuszami. Przekaż inny obiekt arkusza jako pierwszy parametr. This functionality proves essential when managing multiple worksheets or creating summary sheets from detailed data.

Zwróć uwagęW poniższym przykładzie, pierwszy parametr metody Copy to arkusz "Sheet2": workBook.GetWorksheet("Sheet2")

:path=/static-assets/excel/content-code-examples/how-to/copy-cells-copy-to-other-worksheet.cs
using IronXL;

WorkBook workBook = WorkBook.Load("multisheet.xlsx");
WorkSheet sheet1 = workBook.GetWorkSheet("Sheet1");
WorkSheet sheet2 = workBook.GetWorkSheet("Sheet2");

// Copy entire data range from Sheet1 to Sheet2
sheet1["A1:D10"].Copy(sheet2, "A1");

// Copy with formulas intact
sheet1["E1:E10"].Copy(sheet2, "F1");

// Copy formatting from template sheet
WorkSheet templateSheet = workBook.GetWorkSheet("Template");
templateSheet["A1:Z1"].Copy(sheet2, "A15");

workBook.SaveAs("crossSheetCopy.xlsx");
using IronXL;

WorkBook workBook = WorkBook.Load("sample.xlsx");
WorkSheet workSheet = workBook.GetWorkSheet("Sheet1");

// Copy cell content
workSheet["A1"].Copy(workBook.GetWorkSheet("Sheet2"), "B3");

workBook.SaveAs("copyAcrossWorksheet.xlsx");
using IronXL;

WorkBook workBook = WorkBook.Load("multisheet.xlsx");
WorkSheet sheet1 = workBook.GetWorkSheet("Sheet1");
WorkSheet sheet2 = workBook.GetWorkSheet("Sheet2");

// Copy entire data range from Sheet1 to Sheet2
sheet1["A1:D10"].Copy(sheet2, "A1");

// Copy with formulas intact
sheet1["E1:E10"].Copy(sheet2, "F1");

// Copy formatting from template sheet
WorkSheet templateSheet = workBook.GetWorkSheet("Template");
templateSheet["A1:Z1"].Copy(sheet2, "A15");

workBook.SaveAs("crossSheetCopy.xlsx");
Imports IronXL

Dim workBook As WorkBook = WorkBook.Load("sample.xlsx")
Dim workSheet As WorkSheet = workBook.GetWorkSheet("Sheet1")

' Copy cell content
workSheet("A1").Copy(workBook.GetWorkSheet("Sheet2"), "B3")

workBook.SaveAs("copyAcrossWorksheet.xlsx")

Dim workBook2 As WorkBook = WorkBook.Load("multisheet.xlsx")
Dim sheet1 As WorkSheet = workBook2.GetWorkSheet("Sheet1")
Dim sheet2 As WorkSheet = workBook2.GetWorkSheet("Sheet2")

' Copy entire data range from Sheet1 to Sheet2
sheet1("A1:D10").Copy(sheet2, "A1")

' Copy with formulas intact
sheet1("E1:E10").Copy(sheet2, "F1")

' Copy formatting from template sheet
Dim templateSheet As WorkSheet = workBook2.GetWorkSheet("Template")
templateSheet("A1:Z1").Copy(sheet2, "A15")

workBook2.SaveAs("crossSheetCopy.xlsx")
$vbLabelText   $csharpLabel

Jakie są typowe scenariusze kopiowania między arkuszami?

Kopiowanie między arkuszami często służy w następujących sytuacjach:

  1. Tworzenie arkuszy podsumowujących: Kopiowanie kluczowych wskaźników z arkuszy szczegółowych do pulpitów nawigacyjnych
  2. Replikacja szablonów: Kopiowanie sformatowanych szablonów do nowych arkuszy
  3. Konsolidacja danych: Zbierz dane z arkuszy poszczególnych działów do arkuszy głównych
  4. Generowanie raportów: skopiuj przefiltrowane wyniki do oddzielnych arkuszy raportowych
  5. Operacje tworzenia kopii zapasowych: Duplikowanie krytycznych danych do arkuszy kopii zapasowych

When working with formulas that reference other cells, IronXL automatically adjusts relative references based on the new location while maintaining absolute references.

Kiedy należy skopiować do nowego arkusza, a kiedy do istniejącego?

Skopiuj do nowego arkusza, gdy:

  • Tworzenie okresowych raportów (dziennych, tygodniowych, miesięcznych)
  • Oddzielanie przetworzonych danych od danych surowych
  • Tworzenie arkuszy analizy na podstawie danych źródłowych
  • Generowanie widoków danych dostosowanych do potrzeb użytkownika

Skopiuj do istniejącego arkusza, gdy:

  • Dodawanie danych do bieżących logów
  • Aktualizacja sekcji pulpitu nawigacyjnego
  • Konsolidacja wielu źródeł danych
  • Zachowanie historycznych zapisów

For complex scenarios involving multiple sheets, consider using IronXL's ability to work with DataSets and DataTables for sophisticated data manipulation.

Jak radzić sobie z konfliktami nazw arkuszy?

Zapewnij prawidłowe zarządzanie arkuszami podczas kopiowania między arkuszami:

// Check if worksheet exists before copying
if (workBook.GetWorkSheet("TargetSheet") == null)
{
    workBook.CreateWorkSheet("TargetSheet");
}

// Safe copy operation
WorkSheet targetSheet = workBook.GetWorkSheet("TargetSheet");
sourceSheet["A1:Z100"].Copy(targetSheet, "A1");
// Check if worksheet exists before copying
if (workBook.GetWorkSheet("TargetSheet") == null)
{
    workBook.CreateWorkSheet("TargetSheet");
}

// Safe copy operation
WorkSheet targetSheet = workBook.GetWorkSheet("TargetSheet");
sourceSheet["A1:Z100"].Copy(targetSheet, "A1");
' Check if worksheet exists before copying
If workBook.GetWorkSheet("TargetSheet") Is Nothing Then
    workBook.CreateWorkSheet("TargetSheet")
End If

' Safe copy operation
Dim targetSheet As WorkSheet = workBook.GetWorkSheet("TargetSheet")
sourceSheet("A1:Z100").Copy(targetSheet, "A1")
$vbLabelText   $csharpLabel

Takie podejście zapobiega błędom wykonawczym i zapewnia pomyślne operacje kopiowania, co jest szczególnie ważne podczas automatyzacji procesów Excel w środowiskach produkcyjnych.

Często Zadawane Pytania

Jak skopiować pojedynczą komórkę w Excel za pomocą C#?

Za pomocą IronXL można skopiować pojedynczą komórkę używając metody Copy. Wystarczy wybrać komórkę do skopiowania (np. workSheet["A1"]) i wywołać metodę Copy, przekazując docelowy arkusz i adres docelowej komórki jako parametry. IronXL zachowuje całe formatowanie, w tym czcionki, kolory, obramowania i formuły podczas operacji kopiowania.

Jakie formatowanie jest zachowywane przy kopiowaniu komórek?

Metoda Copy IronXL zachowuje wszystkie właściwości komórki, w tym wartości komórki i formuły, formaty liczbowe (waluty, procenty, daty), styl czcionki (krój, rozmiar, pogrubienie, kursywa, kolor), obramowania komórki i kolory tła, wyrównanie tekstu (pionowe i poziome) oraz ustawienia ochrony komórki. Dzięki temu skopiowane komórki zachowują swój oryginalny wygląd i funkcjonalność.

Czy mogę skopiować całe kolumny lub zakresy na raz?

Tak, IronXL pozwala na kopiowanie całych kolumn, wierszy lub zakresów w jednej operacji. Można użyć metod takich jak GetColumn(0).Copy() do kopiowania całej kolumny, lub wybrać zakres komórek, aby skopiować wiele komórek jednocześnie. Metoda Copy działa z dowolnym rozmiarem selekcji, od pojedynczych komórek po całe arkusze.

Jak skopiować komórki między różnymi arkuszami?

IronXL ułatwia kopiowanie komórek między arkuszami. Podczas korzystania z metody Copy, określ docelowy arkusz jako pierwszy parametr (np. workBook.GetWorkSheet("Sheet2")) i adres docelowej komórki jako drugi parametr. Pozwala to na kopiowanie danych między różnymi arkuszami w tym samym skoroszycie.

Jakie są minimalne kroki wymagane do skopiowania komórek w Excel?

Z IronXL kopiowanie komórek wymaga tylko 5 kroków: 1) Pobierz bibliotekę IronXL C#, 2) Załaduj istniejący arkusz Excel, 3) Wybierz zakres, wiersz lub kolumnę, które chcesz skopiować, 4) Wywołaj metodę Copy na wybranym zakresie, 5) Przekaż docelowy arkusz i pozycję do metody Copy. Cała operacja może być wykonana w jednej linii kodu.

Curtis Chau
Autor tekstów technicznych

Curtis Chau posiada tytuł licencjata z informatyki (Uniwersytet Carleton) i specjalizuje się w front-endowym rozwoju, z ekspertką w Node.js, TypeScript, JavaScript i React. Pasjonuje się tworzeniem intuicyjnych i estetycznie przyjemnych interfejsów użytkownika, Curtis cieszy się pracą z nowoczesnymi frameworkami i tworzeniem dobrze zorganizowanych, atrakcyjnych wizualnie podrę...

Czytaj więcej
Gotowy, aby rozpocząć?
Nuget Pliki do pobrania 1,950,735 | Wersja: 2026.4 just released
Still Scrolling Icon

Wciąż przewijasz?

Czy chcesz szybko dowodu? PM > Install-Package IronXl.Excel
uruchom próbkę zobacz, jak Twoje dane stają się arkuszem.