Skip to content

Встановлення клітинок у XLSX

set_cell(sheet_index, cell_ref, value) пише значення в worksheet за нульовим індексом листа та стандартним A1-посиланням на клітинку (A1, B12, AA42). Office Oxide приймає рядки, числа, булеві та порожні значення.

Оточення листа — формати, merges, умовне форматування, іменовані діапазони, діаграми — зберігається дослівно.

Запис базових типів

Python

from office_oxide import EditableDocument

with EditableDocument.open("budget.xlsx") as ed:
    ed.set_cell(0, "A1", "Total")     # рядок
    ed.set_cell(0, "B1", 42.5)        # число (int теж)
    ed.set_cell(0, "C1", True)        # булеве
    ed.set_cell(0, "D1", None)        # порожнє
    ed.save("budget.xlsx")

Rust

use office_oxide::edit::EditableDocument;
use office_oxide::xlsx::edit::CellValue;

let mut wb = EditableDocument::open("budget.xlsx")?;
wb.set_cell(0, "A1", CellValue::String("Total".into()))?;
wb.set_cell(0, "B1", CellValue::Number(42.5))?;
wb.set_cell(0, "C1", CellValue::Boolean(true))?;
wb.set_cell(0, "D1", CellValue::Empty)?;
wb.save("budget.xlsx")?;

JavaScript

import { EditableDocument } from 'office-oxide';

using wb = EditableDocument.open('budget.xlsx');

wb.setCell(0, 'A1', 'Total');   // рядок
wb.setCell(0, 'B1', 42.5);      // число
wb.setCell(0, 'C1', true);      // булеве
wb.setCell(0, 'D1', null);      // порожнє

wb.save('budget.xlsx');

Go

ed, _ := officeoxide.OpenEditable("budget.xlsx")
defer ed.Close()

ed.SetCell(0, "A1", officeoxide.NewStringCell("Total"))
ed.SetCell(0, "B1", officeoxide.NewNumberCell(42.5))
ed.SetCell(0, "C1", officeoxide.NewBoolCell(true))
ed.SetCell(0, "D1", officeoxide.NewEmptyCell())

ed.Save("budget.xlsx")

C#

using var wb = EditableDocument.Open("budget.xlsx");

wb.SetCell(0u, "A1", "Total");        // string-перевантаження
wb.SetCell(0u, "B1", 42.5);           // double-перевантаження
wb.SetCell(0u, "C1", true);           // bool-перевантаження
wb.SetCellEmpty(0u, "D1");            // очистити клітинку

wb.Save("budget.xlsx");

Bulk-оновлення

Об’єднуйте багато записів в один цикл open/save.

Python

rows = [
    ("Acme",    120_000, True),
    ("Globex",   85_000, False),
    ("Initech",  62_500, True),
]

with EditableDocument.open("dashboard.xlsx") as ed:
    for i, (name, revenue, active) in enumerate(rows):
        row = i + 2  # рядок 1 лишаємо під заголовки
        ed.set_cell(0, f"A{row}", name)
        ed.set_cell(0, f"B{row}", revenue)
        ed.set_cell(0, f"C{row}", active)
    ed.save("dashboard.xlsx")

Rust

let rows = [
    ("Acme",    120_000.0, true),
    ("Globex",   85_000.0, false),
    ("Initech",  62_500.0, true),
];

let mut ed = EditableDocument::open("dashboard.xlsx")?;
for (i, (name, revenue, active)) in rows.iter().enumerate() {
    let row = i + 2;
    ed.set_cell(0, &format!("A{row}"), CellValue::String((*name).into()))?;
    ed.set_cell(0, &format!("B{row}"), CellValue::Number(*revenue))?;
    ed.set_cell(0, &format!("C{row}"), CellValue::Boolean(*active))?;
}
ed.save("dashboard.xlsx")?;

Націлювання на інші листи

sheet_index — це позиція в книзі, починаючи з нуля, — не ім’я листа. Щоб отримати індекс за іменем, спочатку прочитайте книгу:

Python

from office_oxide import Document, EditableDocument

with Document.open("budget.xlsx") as doc:
    sheet_names = [s.name() for s in doc.as_xlsx().sheets()]
print(sheet_names)   # ['Summary', 'Q1', 'Q2', 'Q3', 'Q4']

idx = sheet_names.index("Q3")
with EditableDocument.open("budget.xlsx") as ed:
    ed.set_cell(idx, "B5", 42_000)
    ed.save("budget.xlsx")

Що set_cell зачіпає, а що ні

set_cell пише значення <v> і тип <t> клітинки; він не:

  • Перераховує формули. Щоб запустити recalc, відкрийте файл у Excel або скористайтеся calc-рушієм.
  • Змінює таблицю shared-strings поза додаванням нового рядка. Наявні рядки залишаються спільними.
  • Змінює формат клітинки, умовне форматування чи іменовані діапазони.

Якщо цільова клітинка зараз містить формулу, set_cell перепише формулу статичним значенням. Щоб писати формули явно, використовуйте форматно-специфічний API xlsx::edit.

Помилки

Симптом Причина
OfficeError::Sheet(idx) (Rust) / IndexError (Python) sheet_index ≥ кількості листів у книзі
OfficeError::CellRef("...") Посилання на клітинку — не валідна A1-нотація
Після Number(value) клітинка виглядає порожньою в Excel Клітинка раніше була відформатована як текст — очистіть формат у Excel або пишіть через форматно-специфічний API

Дивіться також