ບໍລິການ SFDocuments.Calc

ໄລບຣາຣີທີ່ໃຊ້ຮ່ວມກັນ SFDocuments ມີຫຼາຍເມທອດ ແລະ ຄຸນສົມບັດ ເພື່ອອຳນວຍຄວາມສະດວກໃນການຈັດການ ແລະ ການດຳເນີນການກັບເອກະສານ LibreOfficeDev.

ບໍລິການ SFDocuments.Calc ແມ່ນຄລາດຍ່ອຍ (subclass) ຂອງບໍລິການ SFDocuments.Document. ເມທອດ ແລະ ຄຸນສົມບັດທັງໝົດທີ່ກຳນົດໄວ້ສຳລັບບໍລິການ Document ຍັງສາມາດເຂົ້າເຖິງໄດ້ໂດຍໃຊ້ອິນສະແຕນຊ໌ຂອງບໍລິການ Calc.

ບໍລິການ Calc ເນັ້ນໃສ່:

ໄອຄອນ ບັນທຶກ

ໜ້າຊ່ວຍເຫຼືອນີ້ອະທິບາຍກ່ຽວກັບເມທອດ ແລະ ຄຸນສົມບັດທີ່ໃຊ້ໄດ້ກັບເອກະສານ Calc ເທົ່ານັ້ນ.


ການເອີ້ນໃຊ້ບໍລິການ

ກ່ອນທີ່ຈະໃຊ້ບໍລິການ Calc, ໄລບຣາຣີ ScriptForge ຈຳເປັນຕ້ອງໄດ້ຖືກໂຫລດ ຫຼື ນຳເຂົ້າກ່ອນ:

ໄອຄອນ ບັນທຶກ

• ມາໂຄຣ Basic ຕ້ອງມີການໂຫຼດຄັງສຳນວນ ScriptForge ໂດຍໃຊ້ຄຳສັ່ງດັ່ງນີ້:
GlobalScope.BasicLibraries.loadLibrary("ScriptForge")

• ສະຄຣິບ Python ຕ້ອງມີການນຳເຂົ້າຈາກໂມດູນ scriptforge:
from scriptforge import CreateScriptService


ບໍລິການ Calc ມີຄວາມກ່ຽວຂ້ອງກັນຢ່າງໃກ້ຊິດກັບບໍລິການ UI ຂອງໄລບຣາຣີ ScriptForge. ລຸ່ມນີ້ແມ່ນຕົວຢ່າງບາງສ່ວນຂອງວິທີການເອີ້ນໃຊ້ບໍລິການ Calc.

ໃນ Basic

ສ່ວນຂອງໂຄ້ດລຸ່ມນີ້ຈະສ້າງອິນສະແຕນຊ໌ຂອງບໍລິການ Calc ທີ່ກົງກັບເອກະສານ Calc ທີ່ກຳລັງເຮັດວຽກຢູ່ປັດຈຸບັນ.


    Set oDoc = CreateScriptService("Calc")
  

ອີກວິທີໜຶ່ງໃນການສ້າງອິນສະແຕນຊ໌ຂອງບໍລິການ Calc ແມ່ນການໃຊ້ບໍລິການ UI. ໃນຕົວຢ່າງຕໍ່ໄປນີ້, ເອກະສານ Calc ໃໝ່ຈະຖືກສ້າງຂຶ້ນ ແລະ oDoc ຈະເປັນອິນສະແຕນຊ໌ຂອງບໍລິການ Calc:


    Dim ui As Object, oDoc As Object
    Set ui = CreateScriptService("UI")
    Set oDoc = ui.CreateDocument("Calc")
  

ຫຼື ໃຊ້ເມທອດ OpenDocument ຈາກບໍລິການ UI:


    Set oDoc = ui.OpenDocument("C:\Documents\MyFile.ods")
  

ນອກຈາກນັ້ນ ຍັງສາມາດສ້າງອິນສະແຕນຊ໌ຂອງບໍລິການ Calc ໂດຍການລະບຸຊື່ໜ້າຕ່າງສຳລັບເມທອດ CreateScriptService:


    Dim oDoc As Object
    Set oDoc = CreateScriptService("SFDocuments.Calc", "MyFile.ods")
  

ໃນຕົວຢ່າງຂ້າງເທິງ, "MyFile.ods" ແມ່ນຊື່ຂອງໜ້າຕ່າງເອກະສານທີ່ເປີດຢູ່. ຖ້າບໍ່ໄດ້ລະບຸອາກິວເມນນີ້, ຈະຖືວ່າເປັນໜ້າຕ່າງທີ່ກຳລັງເຮັດວຽກຢູ່.

ນອກຈາກນີ້ ຍັງສາມາດເອີ້ນໃຊ້ບໍລິການ Calc ໂດຍໃຊ້ເອກະສານທີ່ອ້າງອີງໂດຍ ThisComponent. ສິ່ງນີ້ມີປະໂຫຍດເປັນພິເສດເມື່ອສັ່ງໃຫ້ມາໂຄຣເຮັດວຽກຈາກພາຍໃນ Basic IDE.


    Dim oDoc As Object
    Set oDoc = CreateScriptService("Calc", ThisComponent)
  

ຂໍແນະນຳໃຫ້ຄືນຊັບພະຍາກອນ (free resources) ຫຼັງຈາກໃຊ້ງານແລ້ວ:


    Set oDoc = oDoc.Dispose()
  

ແນວໃດກໍຕາມ, ຖ້າເອກະສານຖືກປິດໂດຍໃຊ້ເມທອດ CloseDocument, ກໍບໍ່ຈຳເປັນທີ່ຈະຕ້ອງຄືນຊັບພະຍາກອນໂດຍໃຊ້ຄຳສັ່ງທີ່ອະທິບາຍໄວ້ຂ້າງເທິງ.

ໃນ Python

    myDoc = CreateScriptService("Calc")
  

    ui = CreateScriptService("UI")
    myDoc = ui.CreateDocument("Calc")
  

    myDoc = ui.OpenDocument(r"C:\Documents\MyFile.ods")
  

    myDoc = CreateScriptService("SFDocuments.Calc", "MyFile.ods")
    myDoc.Dispose()
  

    bas = CreateScriptService("Basic")
    myDoc = CreateScriptService("Calc", bas.ThisComponent)
  
ໄອຄອນ ເຄັດລັບ

ການໃຊ້ຄຳນຳໜ້າ "SFDocuments." ໃນຂະນະທີ່ເອີ້ນໃຊ້ບໍລິການແມ່ນເປັນທາງເລືອກ.


ຄຳນິຍາມ

ຫຼາຍເມທອດຕ້ອງການ "ແຜ່ນງານ" ຫຼື "ຊ່ວງ" ເປັນອາກິວເມນ. ເຊວສ່ຽວຖືວ່າເປັນກໍລະນີພິເສດຂອງ ຊ່ວງ.

ທັງສອງອາດຈະຖືກສະແດງອອກເປັນຂໍ້ຄວາມ (string) ຫຼື ເປັນການອ້າງອີງ (= ວັດຖຸ) ຂຶ້ນກັບສະຖານະການ:

ຕົວຢ່າງ:

ຕົວຢ່າງລຸ່ມນີ້ຈະສຳເນົາຂໍ້ມູນຈາກເອກະສານ A (ທີ່ເປີດເປັນແບບອ່ານຢ່າງດຽວ ແລະ ຖືກເຊື່ອງໄວ້) ໄປຫາເອກະສານ B.

ໃນ Basic

    Dim oDocA As Object, oDocB As Object
    Set oDocA = ui.OpenDocument("C:\Documents\FileA.ods", Hidden := True, ReadOnly := True)
    Set oDocB = ui.OpenDocument("C:\Documents\FileB.ods")
    oDocB.CopyToRange(oDocA.Range("SheetX.D4:F8"), "D2:F6") 'CopyToRange(source, target)
  
ໃນ Python

    docA = ui.OpenDocument(r"C:\Documents\FileA.ods", hidden = True, readonly = True)
    docB = ui.OpenDocument(r"C:\Documents\FileB.ods")
    docB.CopyToRange(docA.Range("SheetX.D4:F8"), "D2:F6")
  

SheetName

ອາດເປັນຊື່ແຜ່ນງານໃນຮູບແບບ ຂໍ້ຄວາມ ຫຼື ເປັນ ວັດຖຸ ທີ່ສ້າງໂດຍຄຸນສົມບັດ .Sheet.

ທາງລັດ "~" (tilde) ໝາຍເຖິງແຜ່ນງານປັດຈຸບັນ.

RangeName

ອາດເປັນຂໍ້ຄວາມທີ່ກຳນົດຊຸດຂອງເຊວທີ່ຢູ່ຕິດກັນໃນແຜ່ນງານຂອງອິນສະແຕນຊ໌ປັດຈຸບັນ ຫຼື ເປັນ ວັດຖຸ ທີ່ສ້າງໂດຍຄຸນສົມບັດ .Range.

ທາງລັດ "~" (tilde) ໝາຍເຖິງສິ່ງທີ່ເລືອກໄວ້ປັດຈຸບັນ ຫຼື ຊ່ວງທຳອິດທີ່ຖືກເລືອກ ຫາກມີການເລືອກຫຼາຍຊ່ວງ.

ທາງລັດ "*" ໝາຍເຖິງເຊວທັງໝົດທີ່ມີການໃຊ້ງານ.

ຊື່ແຜ່ນງານເປັນສິ່ງທີ່ຈະລະບຸຫຼືບໍ່ກໍໄດ້ເມື່ອກຳນົດຊ່ວງ. ຖ້າບໍ່ມີການລະບຸຊື່ແຜ່ນງານ, ຈະໃຊ້ແຜ່ນງານທີ່ກຳລັງເຮັດວຽກຢູ່. ການໃຊ້ເຄື່ອງໝາຍອັດຕະພາກດ່ຽວ (single quotes) ແລະ ເຄື່ອງໝາຍ $ ແມ່ນອະນຸຍາດໃຫ້ໃຊ້ໄດ້ແຕ່ຈະຖືກລະເລີຍ.

ເມື່ອລະບຸ SheetName ເປັນຂໍ້ຄວາມ, ຈຳເປັນຕ້ອງໃຊ້ເຄື່ອງໝາຍອັດຕະພາກດ່ຽວລ້ອມຮອບຊື່ແຜ່ນງານ ຫາກຊື່ນັ້ນມີຊ່ອງຫວ່າງ " " ຫຼື ເຄື່ອງໝາຍຈ້ຳ ".".

ຕົວຢ່າງລຸ່ມນີ້ສະແດງໃຫ້ເຫັນວ່າກໍລະນີໃດທີ່ຈຳເປັນຕ້ອງໃຊ້ເຄື່ອງໝາຍອັດຕະພາກດ່ຽວ:


      ' ການໃຊ້ເຄື່ອງໝາຍອັດຕະພາກດ່ຽວແມ່ນເປັນທາງເລືອກ
      oDoc.clearAll("SheetA.A1:B10")
      oDoc.clearAll("'SheetA'.A1:B10")
      ' ຈຳເປັນຕ້ອງໃຊ້ເຄື່ອງໝາຍອັດຕະພາກດ່ຽວ
      oDoc.clearAll("'Sheet.A'.A1:B10")
    
ໄອຄອນ ເຄັດລັບ

ຍົກເວັ້ນຄຸນສົມບັດ CurrentSelection, ບໍລິການ Calc ຈະພິຈາລະນາສະເພາະຊ່ວງເຊວດ່ຽວເທົ່ານັ້ນ.


ຕົວຢ່າງຂອງຊ່ວງທີ່ຖືກຕ້ອງ

1) $'SheetX'.D2
2) $D$2

ເຊວດ່ຽວ

1) $'SheetX'.D2:F6
2) D2:D10

ຊ່ວງດ່ຽວທີ່ມີຫຼາຍເຊວ

$'SheetX'.*

ເຊວທັງໝົດທີ່ມີການໃຊ້ງານໃນແຜ່ນງານທີ່ລະບຸ

1) $'SheetX'.A:A (ຄໍລຳ A)
2) 3:5 (ແຖວ 3 ຫາ 5)

ເຊວທັງໝົດໃນຄໍລຳ ຫຼື ແຖວທີ່ຢູ່ຕິດກັນ ຈົນຮອດເຊວສຸດທ້າຍທີ່ມີການໃຊ້ງານ

myRange

ຊ່ວງທີ່ຕັ້ງຊື່ວ່າ "myRange" ໃນລະດັບສະເປຣດຊີດ

1) ~.someRange
2) SheetX.someRange

ຊື່ຂອງຊ່ວງໃນລະດັບແຜ່ນງານ

myDoc.Range("SheetX.D2:F6")

ຊ່ວງພາຍໃນແຜ່ນງານ SheetX ໃນໄຟລ໌ທີ່ກ່ຽວຂ້ອງກັບອິນສະແຕນຊ໌ Calc ຂອງ myDoc

~.~ ຫຼື ~

ສິ່ງທີ່ເລືອກໄວ້ປັດຈຸບັນໃນແຜ່ນງານທີ່ກຳລັງເຮັດວຽກຢູ່


ຄຸນສົມບັດ

ຄຸນສົມບັດທົ່ວໄປທັງໝົດຂອງເອກະສານໃດໆ ກໍສາມາດໃຊ້ໄດ້ກັບເອກະສານ Calc ເຊັ່ນກັນ. ສຳລັບຂໍ້ມູນເພີ່ມເຕີມ, ກະລຸນາອ່ານທີ່ ໜ້າຊ່ວຍເຫຼືອບໍລິການ Document.

ຄຸນສົມບັດທີ່ມີໃຫ້ສະເພາະສຳລັບເອກະສານ Calc ແມ່ນ:

ຊື່

ອ່ານຢ່າງດຽວ

ອາກິວເມນ

ປະເພດຂອງການສົ່ງຄືນ

ຄຳອະທິບາຍ

CurrentSelection

ບໍ່

ບໍ່ມີ

ຂໍ້ຄວາມ ຫຼື ອາເຣຂອງຂໍ້ຄວາມ

ຊ່ວງທີ່ເລືອກໄວ້ດ່ຽວໆເປັນຂໍ້ຄວາມ ຫຼື ລາຍການຂອງຊ່ວງທີ່ເລືອກເປັນອາເຣ.

DefinedNames

ແມ່ນ

ບໍ່ມີ

ຂໍ້ຄວາມ ຫຼື ອາເຣຂອງຂໍ້ຄວາມ

ສົ່ງຄືນລາຍການທີ່ຈັດລຽງແລ້ວຂອງຊ່ວງທີ່ຕັ້ງຊື່ໄວ້ທັງໝົດໃນເອກະສານ. ຊື່ທີ່ກຳນົດໄວ້ໃນແຜ່ນງານດ່ຽວຈະຖືກລະບຸພ້ອມກັບຊື່ແຜ່ນງານ.

FirstCell

ແມ່ນ

SheetName ຫຼື RangeName ເປັນຂໍ້ຄວາມ

String

ສົ່ງຄືນເຊວທຳອິດທີ່ມີການໃຊ້ງານໃນຊ່ວງ ຫຼື ແຜ່ນງານທີ່ລະບຸ.

FirstColumn

ແມ່ນ

SheetName ຫຼື RangeName ເປັນຂໍ້ຄວາມ

Long

ສົ່ງຄືນໝາຍເລກຄໍລຳທາງຊ້າຍສຸດໃນຊ່ວງ ຫຼື ແຜ່ນງານທີ່ລະບຸ.

FirstRow

ແມ່ນ

SheetName ຫຼື RangeName ເປັນຂໍ້ຄວາມ

Long

ສົ່ງຄືນໝາຍເລກແຖວເທິງສຸດໃນຊ່ວງ ຫຼື ແຜ່ນງານທີ່ລະບຸ.

Height

ແມ່ນ

RangeName ເປັນຂໍ້ຄວາມ

Long

ຈຳນວນແຖວ (>= 1) ໃນຊ່ວງທີ່ລະບຸ.

LastCell

ແມ່ນ

SheetName ຫຼື RangeName ເປັນຂໍ້ຄວາມ

String

ສົ່ງຄືນເຊວສຸດທ້າຍທີ່ມີການໃຊ້ງານໃນຊ່ວງ ຫຼື ແຜ່ນງານທີ່ລະບຸ.

LastColumn

ແມ່ນ

SheetName ຫຼື RangeName ເປັນຂໍ້ຄວາມ

Long

ຄໍລຳສຸດທ້າຍທີ່ມີການໃຊ້ງານໃນຊ່ວງ ຫຼື ແຜ່ນງານທີ່ລະບຸ.

LastRow

ແມ່ນ

SheetName ຫຼື RangeName ເປັນຂໍ້ຄວາມ

Long

ແຖວສຸດທ້າຍທີ່ມີການໃຊ້ງານໃນຊ່ວງ ຫຼື ແຜ່ນງານທີ່ລະບຸ.

Range

ແມ່ນ

RangeName ເປັນຂໍ້ຄວາມ

Object

ການອ້າງອີງຊ່ວງທີ່ສາມາດໃຊ້ເປັນອາກິວເມນຂອງເມທອດ ເຊັ່ນ CopyToRange.

Region

ແມ່ນ

RangeName ເປັນຂໍ້ຄວາມ

String

ສົ່ງຄືນທີ່ຢູ່ຂອງພື້ນທີ່ທີ່ນ້ອຍທີ່ສຸດເຊິ່ງກວມເອົາຊ່ວງທີ່ລະບຸ ໂດຍທີ່ພື້ນທີ່ນັ້ນຖືກລ້ອມຮອບດ້ວຍເຊວຫວ່າງ ຫຼື ຂອບຂອງແຜ່ນງານ. ສິ່ງນີ້ທຽບເທົ່າກັບການໃຊ້ທາງລັດ ກັບຊ່ວງທີ່ລະບຸ.

Sheet

ແມ່ນ

SheetName ເປັນຂໍ້ຄວາມ

Object

ການອ້າງອີງແຜ່ນງານທີ່ສາມາດໃຊ້ເປັນອາກິວເມນຂອງເມທອດ ເຊັ່ນ CopySheet.

SheetName

ແມ່ນ

RangeName ເປັນຂໍ້ຄວາມ

String

ສົ່ງຄືນຊື່ແຜ່ນງານຂອງທີ່ຢູ່ຊ່ວງທີ່ລະບຸ.

Sheets

ແມ່ນ

ບໍ່ມີ

ອາເຣຂອງຂໍ້ຄວາມ

ລາຍການຊື່ຂອງແຜ່ນງານທີ່ມີຢູ່ທັງໝົດ.

Width

ແມ່ນ

RangeName ເປັນຂໍ້ຄວາມ

Long

ຈຳນວນຄໍລຳ (>= 1) ໃນຊ່ວງທີ່ລະບຸ.

XCellRange

ແມ່ນ

RangeName ເປັນຂໍ້ຄວາມ

Object

ວັດຖຸ UNO ປະເພດ com.sun.star.Table.XCellRange.

XRectangle

ແມ່ນ

RangeName ເປັນຂໍ້ຄວາມ

Object

ໂຄງສ້າງ UNO ປະເພດ com.sun.star.awt.Rectangle, ເຊິ່ງອະທິບາຍພື້ນທີ່ເທິງໜ້າຈໍທີ່ຊ່ວງນັ້ນຕັ້ງຢູ່ ເປັນໜ່ວຍພິກເຊວ.

XSheetCellCursor

ແມ່ນ

RangeName ເປັນຂໍ້ຄວາມ

Object

ວັດຖຸ UNO ປະເພດ com.sun.star.sheet.XSheetCellCursor. ຫຼັງຈາກຍ້າຍເຄີເຊີແລ້ວ, ທີ່ຢູ່ຊ່ວງທີ່ໄດ້ຮັບສາມາດເຂົ້າເຖິງໄດ້ຜ່ານຄຸນສົມບັດ UNO AbsoluteName ຂອງວັດຖຸເຄີເຊີ, ເຊິ່ງຈະສົ່ງຄືນຄ່າເປັນຂໍ້ຄວາມທີ່ສາມາດໃຊ້ເປັນອາກິວເມນສຳລັບຄຸນສົມບັດ ແລະ ເມທອດຂອງບໍລິການ Calc.

XSpreadsheet

ແມ່ນ

SheetName ເປັນຂໍ້ຄວາມ

Object

ວັດຖຸ UNO ປະເພດ com.sun.star.sheet.XSpreadsheet.


ໄອຄອນ ເຄັດລັບ

ເຂົ້າເບິ່ງເວັບໄຊເອກະສານ API ຂອງ LibreOfficeDev ເພື່ອຮຽນຮູ້ເພີ່ມເຕີມກ່ຽວກັບວັດຖຸ UNO XCellRange, XSheetCellCursor ແລະ XSpreadsheet.


ເມທອດ

ລາຍການເມທອດໃນບໍລິການ Calc

A1Style
Activate
AlignRange
BorderRange
Charts
ClearAll
ClearFormats
ClearValues
ColorizeRange
CompactLeft
CompactUp
CopySheet
CopySheetFromFile
CopyToCell
CopyToRange
CreateChart
CreatePivotTable
DAvg

DCount
DecorateFont
DefineName
DMax
DMin
DSum
ExportRangeToFile
FormatRange
Forms
GetColumnName
GetFormula
GetValue
ImportFromCSVFile
ImportFromDatabase
ImportStylesFromFile
InsertSheet
Intersect
MoveRange

MoveSheet
Offset
OpenRangeSelector
PrintOut
Printf
RemoveDuplicates
RemoveSheet
RenameSheet
SetArray
SetCellStyle
SetFormula
SetValue
ShiftDown
ShiftLeft
ShiftRight
ShiftUp
SortRange


A1Style

ສົ່ງຄືນທີ່ຢູ່ຂອງຊ່ວງເປັນຂໍ້ຄວາມໂດຍອີງຕາມພິກັດຂອງແຜ່ນງານ, ເຊັ່ນ ໝາຍເລກແຖວ ແລະ ຄໍລຳ.

ຫາກລະບຸພຽງແຕ່ພິກັດຄູ່ດຽວ, ຈະສົ່ງຄືນທີ່ຢູ່ຂອງເຊວດ່ຽວ. ອາກິວເມນເພີ່ມເຕີມສາມາດລະບຸເຊວລຸ່ມສຸດດ້ານຂວາຂອງຊ່ວງຮູບສີ່ແຈສາກໄດ້.

ໄວຍາກອນ:

svc.A1Style(row1: int, column1: int, row2: int = 0; column2: int = 0; sheetname: str = "~"): str

ພາຣາມິເຕີ:

row1, column1: ລະບຸໝາຍເລກແຖວ ແລະ ຄໍລຳຂອງເຊວເທິງສຸດດ້ານຊ້າຍໃນຊ່ວງທີ່ຕ້ອງການພິຈາລະນາ. ໝາຍເລກແຖວ ແລະ ຄໍລຳເລີ່ມຕົ້ນທີ່ 1.

row2, column2: ລະບຸໝາຍເລກແຖວ ແລະ ຄໍລຳຂອງເຊວລຸ່ມສຸດດ້ານຂວາໃນຊ່ວງທີ່ຕ້ອງການພິຈາລະນາ. ຖ້າບໍ່ໄດ້ລະບຸອາກິວເມນເຫຼົ່ານີ້, ຫຼື ຖ້າໃຫ້ຄ່າທີ່ນ້ອຍກວ່າ row1 ແລະ column1, ຈະສົ່ງຄືນທີ່ຢູ່ຂອງຊ່ວງເຊວດ່ຽວທີ່ແທນດ້ວຍ row1 ແລະ column1.

sheetname: ຊື່ຂອງແຜ່ນງານທີ່ຈະເພີ່ມໃສ່ທີ່ຢູ່ຂອງຊ່ວງທີ່ສົ່ງຄືນ. ແຜ່ນງານຕ້ອງມີຢູ່ຈິງ. ຄ່າເລີ່ມຕົ້ນແມ່ນ "~" ເຊິ່ງກົງກັບແຜ່ນງານທີ່ກຳລັງເຮັດວຽກຢູ່ປັດຈຸບັນ.

ຕົວຢ່າງ:

ຕົວຢ່າງລຸ່ມນີ້ໃນ Basic ແລະ Python ຖືວ່າ "Sheet1" ແມ່ນແຜ່ນງານທີ່ກຳລັງເຮັດວຽກຢູ່ປັດຈຸບັນ.

ໃນ Basic

    Set oDoc = CreateScriptService("Calc")
    addr1 = oDoc.A1Style(1, 1) ' '$Sheet1'.$A$1
    addr2 = oDoc.A1Style(2, 2, 3, 6) ' '$Sheet1'.$B$2:$F$3
    addr3 = oDoc.A1Style(2, 2, 0, 6) ' '$Sheet1'.$B$2
    addr4 = oDoc.A1Style(3, 4, 3, 8, "Sheet2") ' '$Sheet2'.$D$3:$H$3
    addr5 = oDoc.A1Style(5, 1, SheetName := "Sheet3") ' '$Sheet3'.$A$5
  
ໃນ Python

    doc = CreateScriptService("Calc")
    addr1 = doc.A1Style(1, 1) # '$Sheet1'.$A$1
    addr2 = doc.A1Style(2, 2, 3, 6) # '$Sheet1'.$B$2:$F$3
    addr3 = doc.A1Style(2, 2, 0, 6) # '$Sheet1'.$B$2
    addr4 = doc.A1Style(3, 4, 3, 8, "Sheet2") # '$Sheet2'.$D$3:$H$3
    addr5 = doc.A1Style(5, 1, sheetname="Sheet3") # '$Sheet3'.$A$5
  
ໄອຄອນ ເຄັດລັບ

ເມທອດ A1Style ສາມາດໃຊ້ຮ່ວມກັບຫຼາຍຄຸນສົມບັດ ແລະ ເມທອດຂອງບໍລິການ Calc ທີ່ຕ້ອງການຊ່ວງເປັນອາກິວເມນ ເຊັ່ນ GetValue, GetFormula, ClearAll, ແລະ ອື່ນໆ.


Activate

ຖ້າລະບຸອາກິວເມນ sheetname, ແຜ່ນງານນັ້ນຈະຖືກເປີດໃຊ້ງານ ແລະ ກາຍເປັນແຜ່ນງານທີ່ຖືກເລືອກໃນປັດຈຸບັນ. ຖ້າບໍ່ມີອາກິວເມນນີ້, ໜ້າຕ່າງເອກະສານຈະຖືກເປີດໃຊ້ງານແທນ.

ໄວຍາກອນ:

svc.Activate(sheetname: str = ""): bool

ພາຣາມິເຕີ:

sheetname: ຊື່ຂອງແຜ່ນງານທີ່ຈະເປີດໃຊ້ງານໃນເອກະສານ. ຄ່າເລີ່ມຕົ້ນແມ່ນຂໍ້ຄວາມຫວ່າງ, ໝາຍຄວາມວ່າໜ້າຕ່າງເອກະສານຈະຖືກເປີດໃຊ້ງານໂດຍບໍ່ມີການປ່ຽນແປງແຜ່ນງານທີ່ກຳລັງເຮັດວຽກຢູ່.

ຕົວຢ່າງ:

ຕົວຢ່າງລຸ່ມນີ້ຈະເປີດໃຊ້ງານແຜ່ນງານທີ່ຊື່ວ່າ "Sheet4" ໃນເອກະສານທີ່ກຳລັງເຮັດວຽກຢູ່ປັດຈຸບັນ.

ໃນ Basic

    Dim ui as Variant, oDoc as Object
    Set ui = CreateScriptService("UI")
    Set oDoc = ui.GetDocument(ui.ActiveWindow)
    oDoc.Activate("Sheet4")
  
ໃນ Python

    ui = CreateScriptService("UI")
    myDoc = ui.GetDocument(ui.ActiveWindow)
    myDoc.Activate("Sheet4")
  
ໄອຄອນ ເຄັດລັບ

ການເປີດໃຊ້ງານແຜ່ນງານຈະມີຜົນກໍຕໍ່ເມື່ອປະຕິບັດກັບເອກະສານ Calc ເທົ່ານັ້ນ. ເພື່ອໃຫ້ແນ່ໃຈວ່າທ່ານກຳລັງໃຊ້ເອກະສານ Calc ຢູ່, ທ່ານສາມາດໃຊ້ຄຸນສົມບັດ isCalc ຂອງວັດຖຸເອກະສານ, ເຊິ່ງຈະສົ່ງຄືນຄ່າ True ຫາກເປັນເອກະສານ Calc ແລະ False ໃນກໍລະນີອື່ນ.


AlignRange

ຈັດວາງແນວນອນ ຫຼື ແນວຕັ້ງໃຫ້ກັບຊ່ວງຂອງເຊວ.

ສາມາດລະບຸສູດການກັ່ນຕອງເພື່ອ ກຳນົດວ່າເຊວໃດທີ່ຈະໄດ້ຮັບຜົນກະທົບ.

ໄວຍາກອນ:

svc.AlignRange(targetrange: str, alignment: str, opt filterformula: str, opt filterscope: str)

ພາຣາມິເຕີ:

targetrange: ເຊວ ຫຼື ຊ່ວງໃນຮູບແບບຂໍ້ຄວາມທີ່ຕ້ອງການຈັດວາງໃໝ່.

alignment: ຂໍ້ຄວາມທີ່ລວມເອົາ 1 ຫຼື 2 ຕົວອັກສອນພິມໃຫຍ່ຕໍ່ໄປນີ້ (ຕົວອັກສອນອື່ນໆ ຈະຖືກລະເລີຍ):

filterformula: ສູດ Calc ທີ່ຈະຖືກນຳໃຊ້ກັບຊ່ວງທີ່ລະບຸເພື່ອ ກຳນົດວ່າເຊວໃດຈະໄດ້ຮັບຜົນກະທົບ. ສູດທີ່ລະບຸຕ້ອງສົ່ງຄືນຄ່າ True ຫຼື False. ຖ້າບໍ່ໄດ້ລະບຸອາກິວເມນນີ້, ເຊວທັງໝົດໃນຊ່ວງຈະໄດ້ຮັບຜົນກະທົບ.

filterscope: ກຳນົດວ່າ filterformula ຈະຖືກຂະຫຍາຍໄປຍັງຊ່ວງທີ່ລະບຸແນວໃດ. ອາກິວເມນນີ້ແມ່ນຈຳເປັນຕ້ອງລະບຸ ຫາກມີການລະບຸ filterformula. ຄ່າທີ່ຍອມຮັບມີດັ່ງນີ້:

ຕົວຢ່າງ:

ໃນ Basic

      ' ຈັດໃຫ້ເຊວຕົວເລກທັງໝົດຢູ່ເຄິ່ງກາງ ທັງແນວນອນ ແລະ ແນວຕັ້ງ.
      doc.AlignRange("SheetX.A1:J30", "Middle,Center", filterformula := "=IsNumeric(A1)", filterscope := "CELL")
  
ໃນ Python

      # ຈັດໃຫ້ເຊວຕົວເລກທັງໝົດຢູ່ເຄິ່ງກາງ ທັງແນວນອນ ແລະ ແນວຕັ້ງ.
      doc.AlignRange('SheetX.A1:J30', 'Middle,Center', filterformula = '=IsNumeric(A1)', filterscope = 'CELL')
  

BorderRange

ນຳໃຊ້ຊຸດຂອງເສັ້ນຂອບທັງພາຍໃນ ແລະ ອ້ອມຮອບຊ່ວງຂອງເຊວ.

ເຊວທີ່ໄດ້ຮັບຜົນກະທົບສາມາດກຳນົດໄດ້ດ້ວຍສູດການກັ່ນຕອງ ແລະ ຂອບເຂດຂອງມັນ.

ເສັ້ນຂອບທັງໝົດຈະມີຄວາມກວ້າງ, ຮູບແບບ ແລະ ສີທີ່ເປັນມາດຕະຖານດຽວກັນ. ເສັ້ນຂອບທີ່ມີຢູ່ແລ້ວໃນເຊວ, ແຖວ ຫຼື ຄໍລຳ ທີ່ຈະໄດ້ຮັບຜົນກະທົບ ຈະຖືກລຶບອອກກ່ອນ. ເຊວອື່ນໆ ໃນຊ່ວງຈະບໍ່ມີການປ່ຽນແປງ.

ເພື່ອລຶບຂອບທັງໝົດໃນຊ່ວງ ໃຫ້ກຳນົດ border ເປັນ "" ແລະ ຂ້າມອາກິວເມນ filterformula ໄປ.

ໄວຍາກອນ:

svc.BorderRange(targetrange: str, border: str, opt filterformula: str, opt filterscope: str)

ພາຣາມິເຕີ:

targetrange: ເຊວ ຫຼື ຊ່ວງໃນຮູບແບບຂໍ້ຄວາມທີ່ຕ້ອງການໃສ່ເສັ້ນຂອບ.

border: ຂໍ້ຄວາມທີ່ລວມເອົາຕົວອັກສອນພິມໃຫຍ່ຕໍ່ໄປນີ້ (ຕົວອັກສອນອື່ນໆ ຈະຖືກລະເລີຍ):

filterformula: ສູດ Calc ທີ່ຈະຖືກນຳໃຊ້ກັບຊ່ວງທີ່ລະບຸເພື່ອ ກຳນົດວ່າເຊວໃດຈະໄດ້ຮັບຜົນກະທົບ. ສູດທີ່ລະບຸຕ້ອງສົ່ງຄືນຄ່າ True ຫຼື False. ຖ້າບໍ່ໄດ້ລະບຸອາກິວເມນນີ້, ເຊວທັງໝົດໃນຊ່ວງຈະໄດ້ຮັບຜົນກະທົບ.

filterscope: ກຳນົດວ່າ filterformula ຈະຖືກຂະຫຍາຍໄປຍັງຊ່ວງທີ່ລະບຸແນວໃດ. ອາກິວເມນນີ້ແມ່ນຈຳເປັນຕ້ອງລະບຸ ຫາກມີການລະບຸ filterformula. ຄ່າທີ່ຍອມຮັບມີດັ່ງນີ້:

ຕົວຢ່າງ:

ໃນ Basic

        ' ໃສ່ເສັ້ນຂອບໃຫ້ກັບເຊວຕົວເລກທັງໝົດດ້ວຍເສັ້ນລຸ່ມ, ລວມທັງເສັ້ນແນວນອນດ້ານໃນ.
        doc.BorderRange("SheetX.A1:J30", "HB", filterformula := "=IsNumeric(A1)", filterscope := "CELL")
    
ໃນ Python

        # ໃສ່ເສັ້ນຂອບໃຫ້ກັບເຊວຕົວເລກທັງໝົດດ້ວຍເສັ້ນລຸ່ມ, ລວມທັງເສັ້ນແນວນອນດ້ານໃນ.
        doc.BorderRange('SheetX.A1:J30', 'HB', filterformula = '=IsNumeric(A1)', filterscope = 'CELL')
    

Charts

ສົ່ງຄືນລາຍການຊື່ຂອງວັດຖຸແຜນພູມທັງໝົດໃນແຜ່ນງານທີ່ລະບຸ ຫຼື ສົ່ງຄືນອິນສະແຕນຊ໌ດ່ຽວຂອງບໍລິການ Chart.

ໄວຍາກອນ:

svc.Charts(sheetname: str, chartname: str = ""): obj

ພາຣາມິເຕີ:

sheetname: ຊື່ຂອງແຜ່ນງານທີ່ຕ້ອງການດຶງລາຍການແຜນພູມ ຫຼື ບ່ອນທີ່ແຜນພູມທີ່ລະບຸນັ້ນຕັ້ງຢູ່.

chartname: ຊື່ທີ່ຜູ້ໃຊ້ກຳນົດເອງຂອງວັດຖຸແຜນພູມທີ່ຈະສົ່ງຄືນ. ຖ້າແຜນພູມບໍ່ມີຊື່ທີ່ຜູ້ໃຊ້ກຳນົດ, ສາມາດໃຊ້ຊື່ວັດຖຸພາຍໃນໄດ້. ຖ້າບໍ່ມີອາກິວເມນນີ້, ຈະສົ່ງຄືນລາຍການຊື່ແຜນພູມໃນແຜ່ນງານທີ່ລະບຸ.

ໄອຄອນ ເຄັດລັບ

ໃຊ້ແຖບຂ້າງ Navigator ເພື່ອກວດສອບຊື່ທີ່ກຳນົດໃຫ້ກັບແຜນພູມພາຍໃຕ້ໝວດໝູ່ OLE objects.


ຕົວຢ່າງ:

ໃນ Basic

ຕົວຢ່າງລຸ່ມນີ້ສະແດງຈຳນວນວັດຖຸແຜນພູມໃນ "Sheet1".


    Dim arrNames as Object
    arrNames = oDoc.Charts("Sheet1")
    MsgBox "There are " & UBound(arrNames) + 1 & " charts in Sheet1"
  

ຕົວຢ່າງຕໍ່ໄປນີ້ຈະເຂົ້າເຖິງແຜນພູມທີ່ຊື່ວ່າ "MyChart" ໃນ "Sheet1" ແລະ ສະແດງປະເພດຂອງມັນ.


    Dim oChart as Object
    oChart = oDoc.Charts("Sheet1", "MyChart")
    MsgBox oChart.ChartType
  
ໃນ Python

    bas = CreateScriptService("Basic")
    chart_names = doc.Charts("Sheet1")
    bas.MsgBox(f"There are {len(chart_names)} charts in Sheet1")
  

    chart = doc.Charts("Sheet1", "MyChart")
    bas.MsgBox(chart.ChartType)
  

ClearAll

ລຶບເນື້ອຫາ ແລະ ຮູບແບບທັງໝົດຂອງຊ່ວງທີ່ລະບຸ.

ສາມາດລະບຸສູດການກັ່ນຕອງເພື່ອ ກຳນົດວ່າເຊວໃດທີ່ຈະໄດ້ຮັບຜົນກະທົບ.

ໄວຍາກອນ:

svc.ClearAll(range: str, opt filterformula: str, opt filterscope: str)

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຕ້ອງການລຶບ, ໃນຮູບແບບຂໍ້ຄວາມ.

filterformula: ສູດ Calc ທີ່ຈະຖືກນຳໃຊ້ກັບຊ່ວງທີ່ລະບຸເພື່ອ ກຳນົດວ່າເຊວໃດຈະໄດ້ຮັບຜົນກະທົບ. ສູດທີ່ລະບຸຕ້ອງສົ່ງຄືນຄ່າ True ຫຼື False. ຖ້າບໍ່ໄດ້ລະບຸອາກິວເມນນີ້, ເຊວທັງໝົດໃນຊ່ວງຈະໄດ້ຮັບຜົນກະທົບ.

filterscope: ກຳນົດວ່າ filterformula ຈະຖືກຂະຫຍາຍໄປຍັງຊ່ວງທີ່ລະບຸແນວໃດ. ອາກິວເມນນີ້ແມ່ນຈຳເປັນຕ້ອງລະບຸ ຫາກມີການລະບຸ filterformula. ຄ່າທີ່ຍອມຮັບມີດັ່ງນີ້:

ຕົວຢ່າງ:

ໃນ Basic

    ' ລຶບເຊວທັງໝົດໃນຊ່ວງ SheetX.A1:J10
    oDoc.ClearAll("SheetX.A1:J10")
    ' ລຶບເຊວທັງໝົດໃນຊ່ວງ SheetX.A1:J10 ທີ່ມີຄ່າຫຼາຍກວ່າ 100
    oDoc.ClearAll("SheetX.A1:J10", "=SheetX.A1>100", "CELL")
    ' ລຶບທຸກແຖວໃນຊ່ວງ SheetX.A1:J10 ທີ່ມີຜົນລວມຫຼາຍກວ່າ 500
    oDoc.ClearAll("SheetX.A1:J10", "=SUM(SheetX.A1:J1)>100", "ROW")
    ' ລຶບທຸກຄໍລຳໃນຊ່ວງ SheetX.A1:J10 ທີ່ມີຜົນລວມຫຼາຍກວ່າ 500
    oDoc.ClearAll("SheetX.A1:J10", "=SUM(SheetX.A1:A10)>100", "COLUMN")
  
ໃນ Python

    myDoc.ClearAll("SheetX.A1:F10")
    myDoc.ClearAll("SheetX.A1:J10", "=SheetX.A1>100", "CELL")
    myDoc.ClearAll("SheetX.A1:J10", "=SUM(SheetX.A1:J1)>100", "ROW")
    myDoc.ClearAll("SheetX.A1:J10", "=SUM(SheetX.A1:A10)>100", "COLUMN")
  

ClearFormats

ລຶບຮູບແບບ ແລະ ສະໄຕລ໌ຂອງເຊວໃນຊ່ວງທີ່ລະບຸ.

ສາມາດລະບຸສູດການກັ່ນຕອງເພື່ອ ກຳນົດວ່າເຊວໃດທີ່ຈະໄດ້ຮັບຜົນກະທົບ.

ໄວຍາກອນ:

svc.ClearFormats(range: str, opt filterformula: str, opt filterscope: str)

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຕ້ອງການລຶບຮູບແບບ ແລະ ສະໄຕລ໌, ໃນຮູບແບບຂໍ້ຄວາມ.

filterformula: ສູດ Calc ທີ່ຈະຖືກນຳໃຊ້ກັບຊ່ວງທີ່ລະບຸເພື່ອ ກຳນົດວ່າເຊວໃດຈະໄດ້ຮັບຜົນກະທົບ. ສູດທີ່ລະບຸຕ້ອງສົ່ງຄືນຄ່າ True ຫຼື False. ຖ້າບໍ່ໄດ້ລະບຸອາກິວເມນນີ້, ເຊວທັງໝົດໃນຊ່ວງຈະໄດ້ຮັບຜົນກະທົບ.

filterscope: ກຳນົດວ່າ filterformula ຈະຖືກຂະຫຍາຍໄປຍັງຊ່ວງທີ່ລະບຸແນວໃດ. ອາກິວເມນນີ້ແມ່ນຈຳເປັນຕ້ອງລະບຸ ຫາກມີການລະບຸ filterformula. ຄ່າທີ່ຍອມຮັບມີດັ່ງນີ້:

ຕົວຢ່າງ:

ໃນ Basic

      oDoc.ClearFormats("SheetX.*")
  
ໃນ Python

    myDoc.ClearFormats("SheetX.*")
  
ໄອຄອນ ເຄັດລັບ

ເບິ່ງເອກະສານຂອງເມທອດ ClearAll ສຳລັບຕົວຢ່າງການໃຊ້ອາກິວເມນ filterformula ແລະ filterscope.


ClearValues

ລຶບຄ່າ ແລະ ສູດໃນຊ່ວງທີ່ລະບຸ.

ສາມາດລະບຸສູດການກັ່ນຕອງເພື່ອ ກຳນົດວ່າເຊວໃດທີ່ຈະໄດ້ຮັບຜົນກະທົບ.

ໄວຍາກອນ:

svc.ClearValues(range: str, opt filterformula: str, opt filterscope: str)

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຕ້ອງການລຶບຄ່າ ແລະ ສູດ, ໃນຮູບແບບຂໍ້ຄວາມ.

filterformula: ສູດ Calc ທີ່ຈະຖືກນຳໃຊ້ກັບຊ່ວງທີ່ລະບຸເພື່ອ ກຳນົດວ່າເຊວໃດຈະໄດ້ຮັບຜົນກະທົບ. ສູດທີ່ລະບຸຕ້ອງສົ່ງຄືນຄ່າ True ຫຼື False. ຖ້າບໍ່ໄດ້ລະບຸອາກິວເມນນີ້, ເຊວທັງໝົດໃນຊ່ວງຈະໄດ້ຮັບຜົນກະທົບ.

filterscope: ກຳນົດວ່າ filterformula ຈະຖືກຂະຫຍາຍໄປຍັງຊ່ວງທີ່ລະບຸແນວໃດ. ອາກິວເມນນີ້ແມ່ນຈຳເປັນຕ້ອງລະບຸ ຫາກມີການລະບຸ filterformula. ຄ່າທີ່ຍອມຮັບມີດັ່ງນີ້:

ຕົວຢ່າງ:

ໃນ Basic

      oDoc.ClearValues("SheetX.A1:F10")
  
ໃນ Python

    myDoc.ClearValues("SheetX.A1:F10")
  
ໄອຄອນ ເຄັດລັບ

ເບິ່ງເອກະສານຂອງເມທອດ ClearAll ສຳລັບຕົວຢ່າງການໃຊ້ອາກິວເມນ filterformula ແລະ filterscope.


ColorizeRange

ກຳນົດສີຕົວອັກສອນ ແລະ ສີພື້ນຫຼັງຂອງຊ່ວງເຊວ.

ເຊວທີ່ໄດ້ຮັບຜົນກະທົບສາມາດກຳນົດໄດ້ດ້ວຍສູດການກັ່ນຕອງ ແລະ ຂອບເຂດຂອງມັນ.

ໄວຍາກອນ:

svc.ColorizeRange(targetrange: str, opt foreground: int, opt background: int, opt filterformula: str, opt filterscope: str)

ພາຣາມິເຕີ:

targetrange: ເຊວ ຫຼື ຊ່ວງໃນຮູບແບບຂໍ້ຄວາມທີ່ຕ້ອງການກຳນົດສີໃໝ່.

foreground: ສີຕົວອັກສອນ ຈາກຜົນລັດຂອງຟັງຊັນ RGB(). ຄ່າລົບຈະເປັນການລຶບສີຕົວອັກສອນອອກ

background: ສີພື້ນຫຼັງ ຈາກຜົນລັດຂອງຟັງຊັນ RGB(). ຄ່າລົບຈະເປັນການລຶບສີພື້ນຫຼັງອອກ

filterformula: ສູດ Calc ທີ່ຈະຖືກນຳໃຊ້ກັບຊ່ວງທີ່ລະບຸເພື່ອ ກຳນົດວ່າເຊວໃດຈະໄດ້ຮັບຜົນກະທົບ. ສູດທີ່ລະບຸຕ້ອງສົ່ງຄືນຄ່າ True ຫຼື False. ຖ້າບໍ່ໄດ້ລະບຸອາກິວເມນນີ້, ເຊວທັງໝົດໃນຊ່ວງຈະໄດ້ຮັບຜົນກະທົບ.

filterscope: ກຳນົດວ່າ filterformula ຈະຖືກຂະຫຍາຍໄປຍັງຊ່ວງທີ່ລະບຸແນວໃດ. ອາກິວເມນນີ້ແມ່ນຈຳເປັນຕ້ອງລະບຸ ຫາກມີການລະບຸ filterformula. ຄ່າທີ່ຍອມຮັບມີດັ່ງນີ້:

ຕົວຢ່າງ:

ໃນ Basic

        ' ປ່ຽນສີເຊວຕົວເລກເປັນສີແດງ.
        doc.ColorizeRange("SheetX.A1:J30", background := RGB(255, 0, 0), filterformula := "=IsNumeric(A1), filterscope := "CELL")
    
ໃນ Python

        # ປ່ຽນສີເຊວຕົວເລກເປັນສີແດງ.
        basic = CreateScriptService('basic')
        doc.ColorizeRange('SheetX.A1:J30', background = basic.RGB(255, 0, 0), filterformula = '=IsNumeric(A1)', filterscope = 'CELL')
    

CompactLeft

ລຶບຄໍລຳຂອງຊ່ວງທີ່ລະບຸ ທີ່ກົງກັບເງື່ອນໄຂການກັ່ນຕອງເຊິ່ງຂຽນເປັນສູດ Calc. ການກັ່ນຕອງຈະຖືກນຳໃຊ້ກັບແຕ່ລະຄໍລຳເພື່ອຕັດສິນໃຈວ່າຈະລຶບຫຼືບໍ່.

ຄໍລຳທີ່ຖືກລຶບສາມາດຈຳກັດຢູ່ທີ່ຄວາມສູງຂອງຊ່ວງທີ່ລະບຸ ຫຼື ຂະຫຍາຍໄປຕາມຄວາມສູງຂອງແຜ່ນງານທັງໝົດ, ເຊິ່ງຈະເປັນການລຶບຄໍລຳທັງໝົດ.

ເມທອດນີ້ສົ່ງຄືນຂໍ້ຄວາມທີ່ເປັນທີ່ຢູ່ຂອງຊ່ວງທີ່ຖືກບີບອັດແລ້ວ. ຖ້າຄໍລຳທັງໝົດຖືກລຶບ, ຈະສົ່ງຄືນຂໍ້ຄວາມຫວ່າງ.

ໄອຄອນ ບັນທຶກ

ຫາກມີການເລືອກຊ່ວງຂອງເຊວໄວ້, ການເອີ້ນໃຊ້ເມທອດນີ້ຈະບໍ່ມີຜົນກະທົບຕໍ່ສິ່ງທີ່ເລືອກ.


ໄວຍາກອນ:

svc.CompactLeft(range: str, wholecolumn: bool = False, opt filterformula: str): str

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຕ້ອງການລຶບຄໍລຳ, ໃນຮູບແບບຂໍ້ຄວາມ.

wholecolumn: ຖ້າກຳນົດຕົວເລືອກນີ້ເປັນ True, ຄໍລຳທັງໝົດຈະຖືກລຶບອອກຈາກແຜ່ນງານ. ຄ່າເລີ່ມຕົ້ນແມ່ນ False, ເຊິ່ງໝາຍຄວາມວ່າການລຶບຄໍລຳຈະຈຳກັດຢູ່ທີ່ຄວາມສູງຂອງ ຊ່ວງ ທີ່ລະບຸ.

filterformula: ເງື່ອນໄຂການກັ່ນຕອງທີ່ຈະໃຊ້ກັບແຕ່ລະຄໍລຳເພື່ອຕັດສິນໃຈວ່າຈະລຶບຫຼືບໍ່. ເງື່ອນໄຂນີ້ສະແດງອອກເປັນສູດ Calc ທີ່ຈະຖືກນຳໃຊ້ກັບຄໍລຳທຳອິດ. ເມື່ອສູດສົ່ງຄືນຄ່າ True ສຳລັບຄໍລຳໃດ, ຄໍລຳນັ້ນຈະຖືກລຶບ. ຄ່າເລີ່ມຕົ້ນຂອງການກັ່ນຕອງແມ່ນລຶບທຸກຄໍລຳທີ່ຫວ່າງ.

ຕົວຢ່າງ: ສົມມຸດວ່າເລືອກຊ່ວງ A1:J200 (ຄວາມສູງ = 200), ສູດເລີ່ມຕົ້ນແມ່ນ =(COUNTBLANK(A1:A200)=200). ນີ້ໝາຍຄວາມວ່າຖ້າທັງ 200 ເຊວໃນຄໍລຳທຳອິດ (ຄໍລຳ A) ຫວ່າງທັງໝົດ, ຄໍລຳນັ້ນຈະຖືກລຶບ. ໃຫ້ສັງເກດວ່າສູດຖືກຂຽນໂດຍອ້າງອີງໃສ່ຄໍລຳທຳອິດເທົ່ານັ້ນ. ພາຍໃນເມທອດ CompactLeft ຈະນຳໃຊ້ສູດນີ້ກັບທຸກຄໍລຳທີ່ເຫຼືອໂດຍອັດຕະໂນມັດ.

ໄອຄອນ ບັນທຶກ

ຟັງຊັນ Calc ທີ່ໃຊ້ໃນອາກິວເມນ filterformula ຕ້ອງຂຽນເປັນຊື່ພາສາອັງກິດ. ເຂົ້າເບິ່ງໜ້າ Wiki List of Calc Functions ສຳລັບລາຍຊື່ຟັງຊັນ Calc ທັງໝົດໃນພາສາອັງກິດ.


ຕົວຢ່າງ:

ໃນ Basic

    ' ລຶບຄໍລຳຫວ່າງທັງໝົດໃນຊ່ວງ G1:L10 ຈາກ Sheet1
    newrange = oDoc.CompactLeft("Sheet1.G1:L10")
    ' ຕົວຢ່າງລຸ່ມນີ້ຄ້າຍຄືກັນ, ແຕ່ຄໍລຳທັງໝົດຈະຖືກລຶບອອກຈາກແຜ່ນງານ
    newrange = oDoc.CompactLeft("Sheet1.G1:L10", WholeColumn := True)
    ' ລຶບທຸກຄໍລຳທີ່ແຖວທຳອິດຖືກໝາຍດ້ວຍ "X"
    newrange = oDoc.CompactLeft("Sheet1.G1:L10", FilterFormula := "=(G1=""X"")")
    ' ລຶບທຸກຄໍລຳທີ່ຜົນລວມຂອງຄ່າໃນຄໍລຳນັ້ນເປັນເລກຄີກ
    newrange = oDoc.CompactLeft("Sheet1.G1:L10", FilterFormula := "=(MOD(SUM(G1:G10);2)=1)")
  
ໃນ Python

    newrange = myDoc.CompactLeft("Sheet1.G1:L10")
    newrange = myDoc.CompactLeft("Sheet1.G1:L10", wholecolumn = True)
    newrange = myDoc.CompactLeft("Sheet1.G1:L10", filterformula = '=(G1="X")')
    newrange = myDoc.CompactLeft("Sheet1.G1:L10", filterformula = '=(MOD(SUM(G1:G10);2)=1)')
  

CompactUp

ລຶບແຖວຂອງຊ່ວງທີ່ລະບຸ ທີ່ກົງກັບເງື່ອນໄຂການກັ່ນຕອງເຊິ່ງຂຽນເປັນສູດ Calc. ການກັ່ນຕອງຈະຖືກນຳໃຊ້ກັບແຕ່ລະແຖວເພື່ອຕັດສິນໃຈວ່າຈະລຶບຫຼືບໍ່.

ແຖວທີ່ຖືກລຶບສາມາດຈຳກັດຢູ່ທີ່ຄວາມກວ້າງຂອງຊ່ວງທີ່ລະບຸ ຫຼື ຂະຫຍາຍໄປຕາມຄວາມກວ້າງຂອງແຜ່ນງານທັງໝົດ, ເຊິ່ງຈະເປັນການລຶບແຖວທັງໝົດ.

ເມທອດນີ້ສົ່ງຄືນຂໍ້ຄວາມທີ່ເປັນທີ່ຢູ່ຂອງຊ່ວງທີ່ຖືກບີບອັດແລ້ວ. ຖ້າແຖວທັງໝົດຖືກລຶບ, ຈະສົ່ງຄືນຂໍ້ຄວາມຫວ່າງ.

ໄອຄອນ ບັນທຶກ

ຫາກມີການເລືອກຊ່ວງຂອງເຊວໄວ້, ການເອີ້ນໃຊ້ເມທອດນີ້ຈະບໍ່ມີຜົນກະທົບຕໍ່ສິ່ງທີ່ເລືອກ.


ໄວຍາກອນ:

svc.CompactUp(range: str, wholerow: bool = False, opt filterformula: str): str

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຕ້ອງການລຶບແຖວ, ໃນຮູບແບບຂໍ້ຄວາມ.

wholerow: ຖ້າກຳນົດຕົວເລືອກນີ້ເປັນ True, ແຖວທັງໝົດຈະຖືກລຶບອອກຈາກແຜ່ນງານ. ຄ່າເລີ່ມຕົ້ນແມ່ນ False, ເຊິ່ງໝາຍຄວາມວ່າການລຶບແຖວຈະຈຳກັດຢູ່ທີ່ຄວາມກວ້າງຂອງ ຊ່ວງ ທີ່ລະບຸ.

filterformula: ເງື່ອນໄຂການກັ່ນຕອງທີ່ຈະໃຊ້ກັບແຕ່ລະແຖວເພື່ອຕັດສິນໃຈວ່າຈະລຶບຫຼືບໍ່. ເງື່ອນໄຂນີ້ສະແດງອອກເປັນສູດ Calc ທີ່ຈະຖືກນຳໃຊ້ກັບແຖວທຳອິດ. ເມື່ອສູດສົ່ງຄືນຄ່າ True ສຳລັບແຖວໃດ, ແຖວນັ້ນຈະຖືກລຶບ. ຄ່າເລີ່ມຕົ້ນຂອງການກັ່ນຕອງແມ່ນລຶບທຸກແຖວທີ່ຫວ່າງ.

ຕົວຢ່າງ: ສົມມຸດວ່າເລືອກຊ່ວງ A1:J200 (ຄວາມກວ້າງ = 10), ສູດເລີ່ມຕົ້ນແມ່ນ =(COUNTBLANK(A1:J1)=10). ນີ້ໝາຍຄວາມວ່າຖ້າທັງ 10 ເຊວໃນແຖວທຳອິດ (ແຖວ 1) ຫວ່າງທັງໝົດ, ແຖວນັ້ນຈະຖືກລຶບ. ໃຫ້ສັງເກດວ່າສູດຖືກຂຽນໂດຍອ້າງອີງໃສ່ແຖວທຳອິດເທົ່ານັ້ນ. ພາຍໃນເມທອດ CompactUp ຈະນຳໃຊ້ສູດນີ້ກັບທຸກແຖວທີ່ເຫຼືອໂດຍອັດຕະໂນມັດ.

ໄອຄອນ ບັນທຶກ

ຟັງຊັນ Calc ທີ່ໃຊ້ໃນສູດທີ່ລະບຸໃນອາກິວເມນ filterformula ຕ້ອງຂຽນເປັນຊື່ພາສາອັງກິດ. ເຂົ້າເບິ່ງໜ້າ Wiki List of Calc Functions ສຳລັບລາຍຊື່ຟັງຊັນ Calc ທັງໝົດໃນພາສາອັງກິດ.


ຕົວຢ່າງ:

ໃນ Basic

    ' ລຶບແຖວຫວ່າງທັງໝົດໃນຊ່ວງ G1:L10 ຈາກ Sheet1
    newrange = oDoc.CompactUp("Sheet1.G1:L10")
    ' ຕົວຢ່າງລຸ່ມນີ້ຄ້າຍຄືກັນ, ແຕ່ແຖວທັງໝົດຈະຖືກລຶບອອກຈາກແຜ່ນງານ
    newrange = oDoc.CompactUp("Sheet1.G1:L10", WholeRow := True)
    ' ລຶບທຸກແຖວທີ່ຄໍລຳທຳອິດຖືກໝາຍດ້ວຍ "X"
    newrange = oDoc.CompactUp("Sheet1.G1:L10", FilterFormula := "=(G1=""X"")")
    ' ລຶບທຸກແຖວທີ່ຜົນລວມຂອງຄ່າໃນແຖວນັ້ນເປັນເລກຄີກ
    newrange = oDoc.CompactUp("Sheet1.G1:L10", FilterFormula := "=(MOD(SUM(G1:L1);2)=1)")
  
ໃນ Python

    newrange = myDoc.CompactUp("Sheet1.G1:L10")
    newrange = myDoc.CompactUp("Sheet1.G1:L10", wholerow = True)
    newrange = myDoc.CompactUp("Sheet1.G1:L10", filterformula = '=(G1="X")')
    newrange = myDoc.CompactUp("Sheet1.G1:L10", filterformula = '=(MOD(SUM(G1:L1);2)=1)')
  

CopySheet

ສຳເນົາແຜ່ນງານທີ່ລະບຸໄປໄວ້ກ່ອນແຜ່ນງານທີ່ມີຢູ່ ຫຼື ໄວ້ທ້າຍສຸດຂອງລາຍການແຜ່ນງານ. ແຜ່ນງານທີ່ຈະສຳເນົາອາດຈະຢູ່ໃນເອກະສານ Calc ໃດກໍໄດ້ທີ່ ເປີດ ຢູ່. ສົ່ງຄືນ True ຫາກສຳເລັດ.

ໄວຍາກອນ:

svc.CopySheet(sheetname: any, newname: str, [beforesheet: any]): bool

ພາຣາມິເຕີ:

sheetname: ຊື່ຂອງແຜ່ນງານທີ່ຈະສຳເນົາ ໃນຮູບແບບຂໍ້ຄວາມ ຫຼື ການອ້າງອີງໃນຮູບແບບວັດຖຸ.

newname: ຊື່ຂອງແຜ່ນງານທີ່ຈະແຊກເຂົ້າ. ຊື່ນັ້ນຕ້ອງບໍ່ຊ້ຳກັບຊື່ທີ່ມີຢູ່ແລ້ວໃນເອກະສານ.

beforesheet: ຊື່ (ຂໍ້ຄວາມ) ຫຼື ອິນເດັກ (ຕົວເລກ, ເລີ່ມຕົ້ນທີ່ 1) ຂອງແຜ່ນງານທີ່ຕ້ອງການແຊກແຜ່ນງານທີ່ສຳເນົາໄວ້ທາງໜ້າ. ອາກິວເມນນີ້ເປັນທາງເລືອກ ແລະ ຄ່າເລີ່ມຕົ້ນແມ່ນການເພີ່ມແຜ່ນງານທີ່ສຳເນົາໄວ້ທີ່ຕຳແໜ່ງສຸດທ້າຍ.

ຕົວຢ່າງ:

ໃນ Basic

ຕົວຢ່າງຕໍ່ໄປນີ້ຈະສ້າງສຳເນົາຂອງແຜ່ນງານ "SheetX" ແລະ ວາງມັນໄວ້ເປັນແຜ່ນງານສຸດທ້າຍໃນເອກະສານປັດຈຸບັນ. ຊື່ຂອງແຜ່ນງານທີ່ສຳເນົາແມ່ນ "SheetY".


    Dim oDoc as Object
    'ດຶງວັດຖຸ Document ຂອງໜ້າຕ່າງທີ່ກຳລັງເຮັດວຽກຢູ່
    Set oDoc = CreateScriptService("Calc")
    oDoc.CopySheet("SheetX", "SheetY")
  

ຕົວຢ່າງລຸ່ມນີ້ຈະສຳເນົາ "SheetX" ຈາກ "FileA.ods" ແລະ ວາງມັນໄວ້ທີ່ຕຳແໜ່ງສຸດທ້າຍຂອງ "FileB.ods" ໂດຍໃຊ້ຊື່ວ່າ "SheetY":


      Dim oDocA As Object : Set oDocA = ui.OpenDocument("C:\Documents\FileA.ods", Hidden := True, ReadOnly := True)
      Dim oDocB As Object : Set oDocB = ui.OpenDocument("C:\Documents\FileB.ods")
      oDocB.CopySheet(oDocA.Sheet("SheetX"), "SheetY")
  
ໃນ Python

    myDoc.CopySheet("SheetX", "SheetY")
  

    docA = ui.OpenDocument(r"C:\Documents\FileA.ods", hidden = True, readonly = True)
    docB = ui.OpenDocument(r"C:\Documents\FileB.ods")
    docB.CopySheet(docA.Sheet("SheetX"), "SheetY")
  
ໄອຄອນ ເຄັດລັບ

ເພື່ອສຳເນົາແຜ່ນງານລະຫວ່າງເອກະສານທີ່ ເປີດ ຢູ່, ໃຫ້ໃຊ້ CopySheet. ເພື່ອສຳເນົາແຜ່ນງານຈາກເອກະສານທີ່ ປິດ ຢູ່, ໃຫ້ໃຊ້ CopySheetFromFile.


CopySheetFromFile

ສຳເນົາແຜ່ນງານທີ່ລະບຸຈາກເອກະສານ Calc ທີ່ ປິດ ຢູ່ ແລະ ວາງມັນໄວ້ກ່ອນແຜ່ນງານທີ່ມີຢູ່ ຫຼື ໄວ້ທ້າຍສຸດຂອງລາຍການແຜ່ນງານຂອງໄຟລ໌ທີ່ອ້າງອີງໂດຍວັດຖຸ Document.

ຖ້າໄຟລ໌ບໍ່ມີຢູ່, ຈະເກີດຂໍ້ຜິດພາດຂຶ້ນ. ຖ້າໄຟລ໌ບໍ່ແມ່ນໄຟລ໌ Calc ທີ່ຖືກຕ້ອງ, ແຜ່ນງານຫວ່າງຈະຖືກແຊກເຂົ້າ. ຖ້າແຜ່ນງານຕົ້ນທາງບໍ່ມີຢູ່ໃນໄຟລ໌ນຳເຂົ້າ, ຂໍ້ຄວາມສະແດງຂໍ້ຜິດພາດຈະຖືກແຊກໄວ້ທີ່ສ່ວນເທິງຂອງແຜ່ນງານທີ່ວາງໃໝ່.

ໄວຍາກອນ:

svc.CopySheetFromFile(filename: str, sheetname: str, newname: str, [beforesheet: any]): bool

ພາຣາມິເຕີ:

filename: ລະບຸໄຟລ໌ທີ່ຈະເປີດ. ຕ້ອງເປັນໄປຕາມຮູບແບບການຕັ້ງຊື່ໄຟລ໌ຂອງ SF_FileSystem.FileNaming. ໄຟລ໌ນັ້ນຕ້ອງບໍ່ມີການປ້ອງກັນດ້ວຍລະຫັດຜ່ານ.

sheetname: ຊື່ຂອງແຜ່ນງານທີ່ຈະສຳເນົາ ໃນຮູບແບບຂໍ້ຄວາມ.

newname: ຊື່ຂອງແຜ່ນງານທີ່ສຳເນົາທີ່ຈະແຊກເຂົ້າໃນເອກະສານ. ຊື່ນັ້ນຕ້ອງບໍ່ຊ້ຳກັບຊື່ທີ່ມີຢູ່ແລ້ວໃນເອກະສານ.

beforesheet: ຊື່ (ຂໍ້ຄວາມ) ຫຼື ອິນເດັກ (ຕົວເລກ, ເລີ່ມຕົ້ນທີ່ 1) ຂອງແຜ່ນງານທີ່ຕ້ອງການແຊກແຜ່ນງານທີ່ສຳເນົາໄວ້ທາງໜ້າ. ອາກິວເມນນີ້ເປັນທາງເລືອກ ແລະ ຄ່າເລີ່ມຕົ້ນແມ່ນການເພີ່ມແຜ່ນງານທີ່ສຳເນົາໄວ້ທີ່ຕຳແໜ່ງສຸດທ້າຍ.

ຕົວຢ່າງ:

ຕົວຢ່າງຕໍ່ໄປນີ້ຈະສຳເນົາ "SheetX" ຈາກ "myFile.ods" ແລະ ວາງມັນລົງໃນເອກະສານທີ່ອ້າງອີງໂດຍ "oDoc" ໂດຍໃຊ້ຊື່ວ່າ "SheetY" ທີ່ຕຳແໜ່ງທຳອິດ.

ໃນ Basic

    oDoc.CopySheetFromFile("C:\Documents\myFile.ods", "SheetX", "SheetY", 1)
  
ໃນ Python

    myDoc.CopySheetFromFile(r"C:\Documents\myFile.ods", "SheetX", "SheetY", 1)
  

CopyToCell

ສຳເນົາຊ່ວງຕົ້ນທາງທີ່ລະບຸ (ຄ່າ, ສູດ ແລະ ຮູບແບບ) ໄປຫາຊ່ວງ ຫຼື ເຊວປາຍທາງ. ເມທອດນີ້ຈະຮຽນແບບພຶດຕິກຳຂອງການຄັດລອກ/ວາງ ຈາກຊ່ວງໄປຫາເຊວດ່ຽວ.

ມັນຈະສົ່ງຄືນຂໍ້ຄວາມທີ່ແທນຊ່ວງຂອງເຊວທີ່ຖືກປ່ຽນແປງ. ຂະໜາດຂອງພື້ນທີ່ທີ່ຖືກປ່ຽນແປງຈະຖືກກຳນົດໂດຍຂະໜາດຂອງພື້ນທີ່ຕົ້ນທາງ.

ຊ່ວງຕົ້ນທາງອາດຈະເປັນຂອງເອກະສານອື່ນທີ່ ເປີດ ຢູ່.

ໄວຍາກອນ:

svc.CopyToCell(sourcerange: any, destinationcell: str): str

ພາຣາມິເຕີ:

sourcerange: ຊ່ວງຕົ້ນທາງໃນຮູບແບບຂໍ້ຄວາມເມື່ອມັນຢູ່ໃນເອກະສານດຽວກັນ ຫຼື ເປັນການອ້າງອີງເມື່ອມັນຢູ່ໃນເອກະສານ Calc ອື່ນທີ່ເປີດຢູ່.

destinationcell: ເຊວປາຍທາງທີ່ຈະວາງຊ່ວງຂອງເຊວທີ່ສຳເນົາໄວ້, ໃນຮູບແບບຂໍ້ຄວາມ. ຖ້າລະບຸເປັນຊ່ວງ, ຈະພິຈາລະນາສະເພາະເຊວເທິງສຸດດ້ານຊ້າຍເທົ່ານັ້ນ.

ຕົວຢ່າງ:

ໃນ Basic

ຕໍ່ໄປນີ້ແມ່ນຕົວຢ່າງທີ່ຕົ້ນທາງ ແລະ ປາຍທາງຢູ່ໃນໄຟລ໌ດຽວກັນ:


      oDoc.CopyToCell("SheetX.A1:F10", "SheetY.C5")
  

ຕົວຢ່າງລຸ່ມນີ້ສະແດງວິທີການສຳເນົາຊ່ວງຈາກເອກະສານ Calc ອື່ນທີ່ເປີດຢູ່:


    Dim ui as Variant : ui = CreateScriptService("UI")
    Dim oDocSource As Object, oDocDestination As Object
    'ເປີດເອກະສານຕົ້ນທາງໄວ້ເບື້ອງຫຼັງ (ເຊື່ອງໄວ້)
    Set oDocSource = ui.OpenDocument("C:\SourceFile.ods", Hidden := True, ReadOnly := True)
    Set oDocDestination = CreateScriptService("Calc")
    oDocDestination.CopyToCell(oDocSource.Range("Sheet1.C2:C4"), "SheetT.A5")
    'ຢ່າລືມປິດເອກະສານຕົ້ນທາງ ເພາະມັນຖືກເປີດແບບເຊື່ອງໄວ້
    oDocSource.CloseDocument()
  
ໃນ Python

    docSource = ui.OpenDocument(r"C:\Documents\SourceFile.ods", hidden = True, readonly = True)
    docDestination = CreateScriptService("Calc")
    docDestination.CopyToCell(docSource.Range("Sheet1.C2:C4"), "SheetT.A5")
    docSource.CloseDocument()
  
ໄອຄອນ ເຄັດລັບ

ເພື່ອຈຳລອງການຄັດລອກ/ວາງ ຈາກຊ່ວງໄປຫາເຊວດ່ຽວ, ໃຫ້ໃຊ້ CopyToCell. ເພື່ອຈຳລອງການຄັດລອກ/ວາງ ຈາກຊ່ວງໄປຫາຊ່ວງທີ່ໃຫຍ່ກວ່າ (ໂດຍໃຫ້ເຊວເດີມຖືກເຮັດຊ້ຳຫຼາຍຄັ້ງ), ໃຫ້ໃຊ້ CopyToRange.


CopyToRange

ສຳເນົາຊ່ວງຕົ້ນທາງທີ່ລະບຸ (ຄ່າ, ສູດ ແລະ ຮູບແບບ) ລົງລຸ່ມ ແລະ/ຫຼື ໄປທາງຂວາ ຫາຊ່ວງປາຍທາງ. ເມທອດນີ້ຈະຮຽນແບບພຶດຕິກຳຂອງການຄັດລອກ/ວາງ ຈາກຊ່ວງຕົ້ນທາງໄປຫາຊ່ວງປາຍທາງທີ່ໃຫຍ່ກວ່າ.

ເມທອດນີ້ສົ່ງຄືນຂໍ້ຄວາມທີ່ແທນຊ່ວງຂອງເຊວທີ່ຖືກປ່ຽນແປງ.

ຊ່ວງຕົ້ນທາງອາດຈະເປັນຂອງເອກະສານອື່ນທີ່ ເປີດ ຢູ່.

ໄວຍາກອນ:

svc.CopyToRange(sourcerange: any, destinationrange: str): str

ພາຣາມິເຕີ:

sourcerange: ຊ່ວງຕົ້ນທາງໃນຮູບແບບຂໍ້ຄວາມເມື່ອມັນຢູ່ໃນເອກະສານດຽວກັນ ຫຼື ເປັນການອ້າງອີງເມື່ອມັນຢູ່ໃນເອກະສານ Calc ອື່ນທີ່ເປີດຢູ່.

destinationrange: ປາຍທາງຂອງຊ່ວງເຊວທີ່ສຳເນົາໄວ້, ໃນຮູບແບບຂໍ້ຄວາມ.

ຕົວຢ່າງ:

ໃນ Basic

ສຳເນົາພາຍໃນເອກະສານດຽວກັນ:


    oDoc.CopyToRange("SheetX.A1:F10", "SheetY.C5:J5")
    ' ສົ່ງຄືນຂໍ້ຄວາມຂອງຊ່ວງ: "$SheetY.$C$5:$J$14"
  

ສຳເນົາຈາກໄຟລ໌ໜຶ່ງໄປຫາອີກໄຟລ໌ໜຶ່ງ:


    Dim oDocA As Object : Set oDocA = ui.OpenDocument("C:\Documents\FileA.ods", Hidden := True, ReadOnly := True)
    Dim oDocB As Object : Set oDocB = ui.OpenDocument("C:\Documents\FileB.ods")
    oDocB.CopyToRange(oDocA.Range("SheetX.A1:F10"), "SheetY.C5:J5")
  
ໃນ Python

    doc.CopyToRange("SheetX.A1:F10", "SheetY.C5:J5")
  

    docA = ui.OpenDocument(r"C:\Documents\FileA.ods", hidden = True, readonly = True)
    docB = ui.OpenDocument(r"C:\Documents\FileB.ods")
    docB.CopyToRange(docA.Range("SheetX.A1:F10"), "SheetY.C5:J5")
  

CreateChart

ສ້າງວັດຖຸແຜນພູມໃໝ່ທີ່ສະແດງຂໍ້ມູນໃນຊ່ວງທີ່ລະບຸ. ວັດຖຸແຜນພູມທີ່ສົ່ງຄືນສາມາດນຳໄປຈັດການຕໍ່ໄດ້ໂດຍໃຊ້ບໍລິການ Chart.

ໄວຍາກອນ:

svc.CreateChart(chartname: str, sheetname: str, range: str, columnheader: bool = False, rowheader: bool = False): obj

ພາຣາມິເຕີ:

chartname: ຊື່ທີ່ຜູ້ໃຊ້ກຳນົດເອງຂອງແຜນພູມທີ່ຈະສ້າງ. ຊື່ນັ້ນຕ້ອງບໍ່ຊ້ຳກັນໃນແຜ່ນງານດຽວກັນ.

sheetname: ຊື່ຂອງແຜ່ນງານບ່ອນທີ່ແຜນພູມຈະຖືກວາງໄວ້.

range: ຊ່ວງທີ່ຈະໃຊ້ເປັນແຫຼ່ງຂໍ້ມູນສຳລັບແຜນພູມ. ຊ່ວງນີ້ສາມາດອ້າງອີງເຖິງແຜ່ນງານໃດກໍໄດ້ໃນເອກະສານ Calc.

columnheader: ເມື່ອເປັນ True, ແຖວເທິງສຸດຂອງຊ່ວງຈະຖືກໃຊ້ເປັນປ້າຍຊື່ສຳລັບແກນໝວດໝູ່ ຫຼື ຄຳອະທິບາຍແຜນພູມ (ຄ່າເລີ່ມຕົ້ນ = False).

rowheader: ເມື່ອເປັນ True, ຄໍລຳຊ້າຍສຸດຂອງຊ່ວງຈະຖືກໃຊ້ເປັນປ້າຍຊື່ສຳລັບແກນໝວດໝູ່ ຫຼື ຄຳອະທິບາຍແຜນພູມ (ຄ່າເລີ່ມຕົ້ນ = False).

ຕົວຢ່າງ:

ຕົວຢ່າງລຸ່ມນີ້ໃນ Basic ແລະ Python ຈະສ້າງແຜນພູມໂດຍໃຊ້ຂໍ້ມູນໃນຊ່ວງ "A1:B5" ຂອງ "Sheet1" ແລະ ວາງແຜນພູມໄວ້ໃນ "Sheet2".

ໃນ Basic

    Set oChart = oDoc.CreateChart("MyChart", "Sheet2", "Sheet1.A1:B5", RowHeader := True)
    oChart.ChartType = "Donut"
  
ໃນ Python

    chart = doc.CreateChart("MyChart", "Sheet2", "Sheet1.A1:B5", rowheader=True)
    chart.ChartType = "Donut"
  
ໄອຄອນ ເຄັດລັບ

ເບິ່ງໜ້າຊ່ວຍເຫຼືອກ່ຽວກັບ ບໍລິການ Chart ຂອງ ScriptForge ເພື່ອຮຽນຮູ້ເພີ່ມເຕີມກ່ຽວກັບວິທີການຈັດການວັດຖຸແຜນພູມ. ທ່ານສາມາດປ່ຽນຄຸນສົມບັດຕ່າງໆ ເຊັ່ນ ປະເພດແຜນພູມ, ຊື່ແຜນພູມ ແລະ ແກນ, ລວມທັງຕຳແໜ່ງຂອງແຜນພູມ.


CreatePivotTable

ສ້າງຕາຕະລາງພິວອດ (pivot table) ໃໝ່ ດ້ວຍຄຸນສົມບັດທີ່ກຳນົດໂດຍອາກິວເມນທີ່ສົ່ງໃຫ້ເມທອດ.

ຕ້ອງລະບຸຊື່ສຳລັບຕາຕະລາງພິວອດ. ຖ້າມີຕາຕະລາງພິວອດທີ່ໃຊ້ຊື່ດຽວກັນນີ້ຢູ່ແລ້ວໃນແຜ່ນງານເປົ້າໝາຍ, ມັນຈະຖືກແທນທີ່ໂດຍບໍ່ມີການແຈ້ງເຕືອນ.

ເມທອດນີ້ສົ່ງຄືນຂໍ້ຄວາມທີ່ບັນຈຸຊ່ວງທີ່ຕາຕະລາງພິວອດໃໝ່ຖືກວາງໄວ້.

ໄວຍາກອນ:

svc.CreatePivotTable(pivottablename: str, sourcerange: str, targetcell: str, datafields: str[0..*], rowfields: str[0..*], columnfields: str[0..*], filterbutton: bool = true, rowtotals: bool = true, columntotals: bool = true): str

ພາຣາມິເຕີ:

pivottablename: ຊື່ທີ່ຜູ້ໃຊ້ກຳນົດເອງຂອງຕາຕະລາງພິວອດໃໝ່.

sourcerange: ຊ່ວງທີ່ບັນຈຸຂໍ້ມູນດິບ, ໃນຮູບແບບຂໍ້ຄວາມ. ໂດຍຖືວ່າແຖວທຳອິດບັນຈຸຊື່ຟີວ (field) ທີ່ຈະຖືກໃຊ້ໂດຍຕາຕະລາງພິວອດ.

targetcell: ເຊວເທິງສຸດດ້ານຊ້າຍບ່ອນທີ່ຕາຕະລາງພິວອດໃໝ່ຈະຖືກວາງໄວ້. ຖ້າລະບຸເປັນຊ່ວງ, ຈະພິຈາລະນາສະເພາະເຊວເທິງສຸດດ້ານຊ້າຍເທົ່ານັ້ນ.

datafields: ສາມາດເປັນທັງຂໍ້ຄວາມດ່ຽວ ຫຼື ອາເຣທີ່ບັນຈຸຂໍ້ຄວາມ ເຊິ່ງກຳນົດຊື່ຟີວ ແລະ ຟັງຊັນທີ່ຈະນຳໃຊ້. ເມື່ອລະບຸເປັນອາເຣ, ຕ້ອງເປັນໄປຕາມຮູບແບບ Array("FieldName[;Function]", ...).

ຟັງຊັນທີ່ອະນຸຍາດຄື: Sum, Count, Average, Max, Min, Product, CountNums, StDev, StDevP, Var, VarP ແລະ Median. ຊື່ຟັງຊັນຕ້ອງລະບຸເປັນພາສາອັງກິດ. ເມື່ອຄ່າທັງໝົດເປັນຕົວເລກ, Sum ຈະເປັນຟັງຊັນເລີ່ມຕົ້ນ, ຖ້າບໍ່ດັ່ງນັ້ນ ຟັງຊັນເລີ່ມຕົ້ນຈະແມ່ນ Count.

rowfields ຂໍ້ຄວາມດ່ຽວ ຫຼື ອາເຣທີ່ມີຊື່ຟີວທີ່ຈະຖືກໃຊ້ເປັນແຖວຂອງຕາຕະລາງພິວອດ.

columnfields: ຂໍ້ຄວາມດ່ຽວ ຫຼື ອາເຣທີ່ມີຊື່ຟີວທີ່ຈະຖືກໃຊ້ເປັນຄໍລຳຂອງຕາຕະລາງພິວອດ.

filterbutton: ກຳນົດວ່າຈະສະແດງປຸ່ມການກັ່ນຕອງຢູ່ເທິງຕາຕະລາງພິວອດຫຼືບໍ່ (ຄ່າເລີ່ມຕົ້ນ = True).

rowtotals: ລະບຸວ່າຈະເພີ່ມຄໍລຳແຍກຕ່າງຫາກສຳລັບຜົນລວມຂອງແຖວໃນຕາຕະລາງພິວອດຫຼືບໍ່ (ຄ່າເລີ່ມຕົ້ນ = True).

columntotals: ລະບຸວ່າຈະເພີ່ມແຖວແຍກຕ່າງຫາກສຳລັບຜົນລວມຂອງຄໍລຳໃນຕາຕະລາງພິວອດຫຼືບໍ່ (ຄ່າເລີ່ມຕົ້ນ = True)

ຕົວຢ່າງ:

ໃນ Basic

    Dim vData As Variant, oDoc As Object, ui As Object, sTable As String, sPivot As String
    Set ui = CreateScriptService("UI")
    Set oDoc = ui.CreateDocument("Calc")
    vData = Array(Array("Item", "State", "Team", "2002", "2003", "2004"), _
        Array("Books", "Michigan", "Jean", 14788, 30222, 23490), _
        Array("Candy", "Michigan", "Jean", 26388, 15641, 32849), _
        Array("Pens", "Michigan", "Jean", 16569, 32675, 25396), _
        Array("Books", "Michigan", "Volker", 21961, 21242, 29009), _
        Array("Candy", "Michigan", "Volker", 26142, 22407, 32841))
    sTable = oDoc.SetArray("A1", vData)
    sPivot = oDoc.CreatePivotTable("PT1", sTable, "H1", _
        Array("2002", "2003;count", "2004;average"), _ ' ສາມຟີວຂໍ້ມູນ
        "Item", _ ' ຟີວແຖວດ່ຽວ
        Array("State", "Team"), False) ' ສອງຟີວຄໍລຳ
  
ໃນ Python

    ui = CreateScriptService("UI")
    doc = ui.CreateDocument("Calc")
    vData = [["Item", "State", "Team", "2002", "2003", "2004"],
             ["Books", "Michigan", "Jean", 14788, 30222, 23490],
             ["Candy", "Michigan", "Jean", 26388, 15641, 32849],
             ["Pens", "Michigan", "Jean", 16569, 32675, 25396)],
             ["Books", "Michigan", "Volker", 21961, 21242, 29009],
             ["Candy", "Michigan", "Volker", 26142, 22407, 32841]]
    sTable = doc.SetArray("A1", vData)
    sPivot = doc.CreatePivotTable("PT1", sTable, "H1",
                                  ["2002", "2003;count", "2004;average"],
                                  "Item",
                                  ["State", "Team"], False)
  
ໄອຄອນ ເຄັດລັບ

ເພື່ອຮຽນຮູ້ເພີ່ມເຕີມກ່ຽວກັບຕາຕະລາງພິວອດໃນ LibreOfficeDev Calc, ກະລຸນາອ່ານໜ້າຊ່ວຍເຫຼືອ Pivot Table.


DAvg, DCount, DMax, DMin and DSum

ນຳໃຊ້ຟັງຊັນ Average, Count, Max, Min ແລະ Sum ຕາມລຳດັບ ກັບທຸກເຊວທີ່ມີຄ່າຕົວເລກໃນຊ່ວງທີ່ລະບຸ, ໂດຍບໍ່ລວມຄ່າຈາກແຖວທີ່ຖືກກັ່ນຕອງ ແລະ ຖືກເຊື່ອງໄວ້ ລວມທັງຄໍລຳທີ່ຖືກເຊື່ອງ, ຄືກັນກັບຟັງຊັນໃນແຖບສະຖານະ (status bar).

ໄວຍາກອນ:

svc.DAvg(range: str): float

svc.DCount(range: str): float

svc.DMax(range: str): float

svc.DMin(range: str): float

svc.DSum(range: str): float

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຈະນຳໃຊ້ຟັງຊັນ, ໃນຮູບແບບຂໍ້ຄວາມ.

ຕົວຢ່າງ:

ຕົວຢ່າງລຸ່ມນີ້ຈະນຳໃຊ້ຟັງຊັນ Sum ກັບຊ່ວງ "A1:A1000" ຂອງແຜ່ນງານທີ່ຖືກເລືອກໃນປັດຈຸບັນ:

ໃນ Basic

      result = oDoc.DSum("~.A1:A1000")
  
ໃນ Python

    result = myDoc.DSum("~.A1:A1000")
  
ໄອຄອນ ບັນທຶກ

ເຊວໃນຊ່ວງທີ່ລະບຸທີ່ມີຂໍ້ຄວາມຈະຖືກລະເລີຍໂດຍຟັງຊັນທັງໝົດເຫຼົ່ານີ້. ຕົວຢ່າງ: ເມທອດ DCount ຈະບໍ່ນັບເຊວທີ່ມີຂໍ້ຄວາມ, ແຕ່ຈະນັບສະເພາະເຊວຕົວເລກເທົ່ານັ້ນ.


DecorateFont

ລະບຸຄຸນສົມບັດຂອງຟອນແບບງ່າຍໆ ທີ່ຈະໃຊ້ໃນຊ່ວງຂອງເຊວ.

ເຊວທີ່ໄດ້ຮັບຜົນກະທົບສາມາດກຳນົດໄດ້ດ້ວຍສູດການກັ່ນຕອງ ແລະ ຂອບເຂດຂອງມັນ.

ເພື່ອປັບແຕ່ງຟອນທີ່ຊັບຊ້ອນກວ່ານີ້, ໃຫ້ໃຊ້ຄຸນສົມບັດ UNO ຕ່າງໆ ທີ່ມີຢູ່ໃນອິນເຕີເຟດ XCell ຫຼື XCellRange.

ໄວຍາກອນ:

svc.DecorateFont(targetrange: str, opt fontname: str, opt fontsize: int, opt decoration: str, opt filterformula: str, opt filterscope: str)

ພາຣາມິເຕີ:

targetrange: ເຊວ ຫຼື ຊ່ວງໃນຮູບແບບຂໍ້ຄວາມທີ່ຕ້ອງການປັບແຕ່ງຟອນໃໝ່.

fontname: ຊື່ຂອງຟອນທີ່ຈະໃຊ້. ລະບົບຈະບໍ່ມີການກວດສອບຊື່. ຄ່າເລີ່ມຕົ້ນ = ບໍ່ມີການປ່ຽນແປງ.

fontsize: ຂະໜາດຂອງຟອນໃນໜ່ວຍພິກເຊວ. ຄ່າເລີ່ມຕົ້ນ = ບໍ່ມີການປ່ຽນແປງ.

decoration: ຂໍ້ຄວາມທີ່ລວມເອົາ 1 ຕົວອັກສອນພິມໃຫຍ່ ຫຼື ຫຼາຍກວ່າຕໍ່ໄປນີ້ (ຕົວອັກສອນອື່ນໆ ຈະຖືກລະເລີຍ). ຄ່າເລີ່ມຕົ້ນ = ບໍ່ມີການປ່ຽນແປງ:

filterformula: ສູດ Calc ທີ່ຈະຖືກນຳໃຊ້ກັບຊ່ວງທີ່ລະບຸເພື່ອ ກຳນົດວ່າເຊວໃດຈະໄດ້ຮັບຜົນກະທົບ. ສູດທີ່ລະບຸຕ້ອງສົ່ງຄືນຄ່າ True ຫຼື False. ຖ້າບໍ່ໄດ້ລະບຸອາກິວເມນນີ້, ເຊວທັງໝົດໃນຊ່ວງຈະໄດ້ຮັບຜົນກະທົບ.

filterscope: ກຳນົດວ່າ filterformula ຈະຖືກຂະຫຍາຍໄປຍັງຊ່ວງທີ່ລະບຸແນວໃດ. ອາກິວເມນນີ້ແມ່ນຈຳເປັນຕ້ອງລະບຸ ຫາກມີການລະບຸ filterformula. ຄ່າທີ່ຍອມຮັບມີດັ່ງນີ້:

ຕົວຢ່າງ:

ໃນ Basic

        ' ປ່ຽນຂະໜາດຟອນ ແລະ ກຳນົດຄຸນສົມບັດຕົວໜາ ແລະ ຂີດກ້ອງໃຫ້ກັບເຊວຕົວເລກ.
        doc.DecorateFont("SheetX.A1:J30", fontsize := 15, decoration := "Bold,Underline", filterformula := "=IsNumeric(A1)", filterscope := "CELL")
    
ໃນ Python

        # ປ່ຽນຂະໜາດຟອນ ແລະ ກຳນົດຄຸນສົມບັດຕົວໜາ ແລະ ຂີດກ້ອງໃຫ້ກັບເຊວຕົວເລກ.
        doc.DecorateFont('SheetX.A1:J30', fontsize = 15, decoration = 'Bold,Underline', filterformula = '=IsNumeric(A1)', filterscope = 'CELL')
    

DefineName

ກຳນົດຊື່ໃໝ່ໃນແຜ່ນງານ, ໃນລະດັບສາກົນ ຫຼື ລະດັບແຜ່ນງານ. ຖ້າມີຊື່ນັ້ນຢູ່ແລ້ວ, ມັນຈະຖືກຂຽນທັບໂດຍບໍ່ມີການແຈ້ງເຕືອນ. ຫຼັງຈາກສ້າງແລ້ວ, ສາມາດໃຊ້ຊື່ໃໝ່ນີ້ໃນສູດໄດ້. ສົ່ງຄືນ True ເມື່ອສຳເລັດ.

ໃຊ້ຄຸນສົມບັດ DefinedNames ເພື່ອກວດສອບຊ່ວງທີ່ຕັ້ງຊື່ໄວ້ທີ່ມີຢູ່.

ໄວຍາກອນ:

svc.DefineName(definedname: str, value: any, opt sheetname: str): boolean

ພາຣາມິເຕີ:

definedname: ຊື່ທີ່ຈະສ້າງ ຫຼື ແກ້ໄຂໂດຍບໍ່ມີການແຈ້ງເຕືອນ. ໝາຍເຫດວ່າຊື່ທີ່ຄືກັນອາດຈະມີຢູ່, ແຕ່ຕ້ອງບໍ່ຢູ່ໃນແຜ່ນງານດຽວກັນ ແລະ ບໍ່ແມ່ນໃນລະດັບສາກົນ.

value: ຊື່ໃໝ່ໃນຮູບແບບ:

ເມື່ອ Value ເປັນຊ່ວງ, ເຊວເທິງສຸດດ້ານຊ້າຍຈະຖືກກຳນົດເປັນເຊວອ້າງອີງ.

sheetname: ຂອບເຂດຂອງຊື່ທີ່ກຳນົດແມ່ນແຜ່ນງານທີ່ລະບຸ. ສາມາດໃຊ້ທາງລັດ "~" ໄດ້.

ຕົວຢ່າງ:

ໃນ Basic

        doc.DefineName("NewName", Sheet := "Sheet3", Value := "H2")
    
ໃນ Python

        doc.DefineName('NewName', sheet = 'Sheet3', value = 'H2')
    

ExportRangeToFile

ສົ່ງອອກຊ່ວງທີ່ລະບຸເປັນຮູບພາບ ຫຼື ໄຟລ໌ PDF.

ເມທອດນີ້ສົ່ງຄືນ True ຫາກບັນທຶກໄຟລ໌ປາຍທາງສຳເລັດ.

ໄອຄອນ ບັນທຶກ

ແຖວ ຫຼື ຄໍລຳທີ່ຖືກເຊື່ອງໄວ້ໃນຊ່ວງທີ່ລະບຸ ຈະບໍ່ຖືກສົ່ງອອກໄປຫາໄຟລ໌ປາຍທາງ.


ໄວຍາກອນ:

svc.ExportRangeToFile(range: str, filename: str, imagetype: str = "pdf", overwrite: bool = False): bool

ພາຣາມິເຕີ:

range: ຊື່ແຜ່ນງານ ຫຼື ຊ່ວງເຊວທີ່ຈະສົ່ງອອກ, ໃນຮູບແບບຂໍ້ຄວາມ.

filename: ຊື່ຂອງໄຟລ໌ທີ່ຈະບັນທຶກ. ຕ້ອງເປັນໄປຕາມຮູບແບບການຕັ້ງຊື່ໄຟລ໌ຂອງ SF_FileSystem.FileNaming.

imagetype: ລະບຸປະເພດໄຟລ໌ປາຍທາງ. ຄ່າທີ່ເປັນໄປໄດ້ຄື "jpeg", "pdf" (ເລີ່ມຕົ້ນ) ແລະ "png".

overwrite: ເມື່ອກຳນົດເປັນ True, ໄຟລ໌ປາຍທາງອາດຈະຖືກຂຽນທັບ (ຄ່າເລີ່ມຕົ້ນ = False).

ຕົວຢ່າງ:

ໃນ Basic

    ' ສົ່ງອອກແຜ່ນງານທັງໝົດເປັນໄຟລ໌ PDF
    oDoc.ExportRangeToFile("SheetX", "C:\Temp\image.pdf")
    ' ສົ່ງອອກຊ່ວງເປັນໄຟລ໌ PNG ແລະ ຂຽນທັບໄຟລ໌ປາຍທາງຫາກມັນມີຢູ່ແລ້ວ
    oDoc.ExportRangeToFile("SheetX.A1:D10", "C:\Temp\image.png", "png", Overwrite := True)
  
ໃນ Python

    doc.ExportRangeToFile("SheetX", r"C:\Temp\image.pdf")
    doc.ExportRangeToFile("SheetX.A1:D10", r"C:\Temp\image.png", "png", overwrite = True)
  

FormatRange

ນຳໃຊ້ຮູບແບບຕົວເລກທີ່ລະບຸ ກັບເຊວ ຫຼື ຊ່ວງຂອງເຊວ.

ເຊວທີ່ໄດ້ຮັບຜົນກະທົບສາມາດກຳນົດໄດ້ດ້ວຍສູດການກັ່ນຕອງ ແລະ ຂອບເຂດຂອງມັນ.

ໄວຍາກອນ:

svc.FormatRange(targetrange: str, numberformat: str, opt locale: str, opt filterformula: str, opt filterscope: str)

ພາຣາມິເຕີ:

targetrange: ເຊວ ຫຼື ຊ່ວງໃນຮູບແບບຂໍ້ຄວາມທີ່ຕ້ອງການຈັດຮູບແບບ.

numberformat: ຮູບແບບທີ່ຈະນຳໃຊ້, ໃນຮູບແບບຂໍ້ຄວາມ.

locale: ການລວມກັນຂອງ la-CO (ພາສາ-ປະເທດ) ເພື່ອລະບຸທ້ອງຖິ່ນ (locale) ທີ່ໃຊ້. ທ້ອງຖິ່ນເລີ່ມຕົ້ນແມ່ນຜົນລັດຈາກຄຸນສົມບັດ platform.FormatLocale

filterformula: ສູດ Calc ທີ່ຈະຖືກນຳໃຊ້ກັບຊ່ວງທີ່ລະບຸເພື່ອ ກຳນົດວ່າເຊວໃດຈະໄດ້ຮັບຜົນກະທົບ. ສູດທີ່ລະບຸຕ້ອງສົ່ງຄືນຄ່າ True ຫຼື False. ຖ້າບໍ່ໄດ້ລະບຸອາກິວເມນນີ້, ເຊວທັງໝົດໃນຊ່ວງຈະໄດ້ຮັບຜົນກະທົບ.

filterscope: ກຳນົດວ່າ filterformula ຈະຖືກຂະຫຍາຍໄປຍັງຊ່ວງທີ່ລະບຸແນວໃດ. ອາກິວເມນນີ້ແມ່ນຈຳເປັນຕ້ອງລະບຸ ຫາກມີການລະບຸ filterformula. ຄ່າທີ່ຍອມຮັບມີດັ່ງນີ້:

ຕົວຢ່າງ:

ໃນ Basic

        ' ຈັດຮູບແບບສະເພາະເຊວທີ່ມີຄ່າຕົວເລກ.
        doc.FormatRange("SheetX.A1:J30", "0,00E+00", filterformula := "=IsNumeric(A1)", filterscope := "CELL")
    
ໃນ Python

        # ຈັດຮູບແບບສະເພາະເຊວທີ່ມີຄ່າຕົວເລກ.
        doc.FormatRange('SheetX.A1:J30', '0,00E+00', filterformula = '=IsNumeric(A1)', filterscope = 'CELL')
    

Forms

ຂຶ້ນກັບພາລາມິເຕີທີ່ລະບຸ, ເມທອດນີ້ຈະສົ່ງຄືນ:

ໄວຍາກອນ:

svc.Forms(sheetname: str): str[0..*]

svc.Forms(sheetname: str, form: str = ''): svc

svc.Forms(sheetname: str, form: int): svc

ພາຣາມິເຕີ:

sheetname: ຊື່ຂອງແຜ່ນງານ, ໃນຮູບແບບຂໍ້ຄວາມ, ບ່ອນທີ່ຕ້ອງການດຶງຟອມ.

form: ຊື່ ຫຼື ອິນເດັກທີ່ກົງກັບຟອມທີ່ເກັບໄວ້ໃນແຜ່ນງານທີ່ລະບຸ. ຖ້າບໍ່ມີອາກິວເມນນີ້, ເມທອດຈະສົ່ງຄືນລາຍການຊື່ຂອງຟອມທັງໝົດທີ່ມີຢູ່ໃນແຜ່ນງານ.

ຕົວຢ່າງ:

ໃນຕົວຢ່າງຕໍ່ໄປນີ້, ແຖວທຳອິດຈະດຶງຊື່ຂອງຟອມທັງໝົດທີ່ເກັບໄວ້ໃນ "Sheet1" ແລະ ແຖວທີສອງຈະດຶງວັດຖຸ Form ຂອງຟອມທີ່ຊື່ວ່າ "Form_A" ເຊິ່ງເກັບໄວ້ໃນ "Sheet1".

ໃນ Basic

    Set FormNames = oDoc.Forms("Sheet1")
    Set FormA = oDoc.Forms("Sheet1", "Form_A")
  
ໃນ Python

    form_names = doc.Forms("Sheet1")
    form_A = doc.Forms("Sheet1", "Form_A")
  

GetColumnName

ແປງໝາຍເລກຄໍລຳທີ່ມີຄ່າລະຫວ່າງ 1 ຫາ 1024 ໃຫ້ເປັນຕົວອັກສອນທີ່ກົງກັນ (ຄໍລຳ 'A', 'B', ..., 'AMJ'). ຖ້າໝາຍເລກຄໍລຳທີ່ໃຫ້ຢູ່ຢູ່ນອກຂອບເຂດທີ່ອະນຸຍາດ, ຈະສົ່ງຄືນຂໍ້ຄວາມຫວ່າງ.

ໄວຍາກອນ:

svc.GetColumnName(columnnumber: int): str

ພາຣາມິເຕີ:

columnnumber: ໝາຍເລກຄໍລຳເປັນຕົວເລກຖ້ວນໃນຊ່ວງ 1 ... 16384.

ຕົວຢ່າງ:

ໃນ Basic

ສະແດງກ່ອງຂໍ້ຄວາມທີ່ມີຊື່ຂອງຄໍລຳທີສາມ, ເຊິ່ງໂດຍຄ່າເລີ່ມຕົ້ນແມ່ນ "C".


    MsgBox oDoc.GetColumnName(3)
  
ໃນ Python

    bas = CreateScriptService("Basic")
    bas.MsgBox(myDoc.GetColumnName(3))
  
ໄອຄອນ ບັນທຶກ

ຈຳນວນຄໍລຳສູງສຸດທີ່ອະນຸຍາດໃນແຜ່ນງານ Calc ແມ່ນ 16384.


GetFormula

ດຶງສູດທີ່ເກັບໄວ້ໃນຊ່ວງເຊວທີ່ລະບຸ ເປັນຂໍ້ຄວາມດ່ຽວ, ອາເຣ 1 ມິຕິ ຫຼື 2 ມິຕິຂອງຂໍ້ຄວາມ.

ໄອຄອນ ບັນທຶກ

ຊື່ຂອງຟັງຊັນ Calc ທີ່ໃຊ້ໃນສູດທີ່ສົ່ງຄືນຈະສະແດງເປັນພາສາອັງກິດ. ເຂົ້າເບິ່ງໜ້າ Wiki List of Calc Functions ສຳລັບລາຍຊື່ຟັງຊັນ Calc ທັງໝົດໃນພາສາອັງກິດ.


ໄວຍາກອນ:

svc.GetFormula(range: str): any

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຕ້ອງການດຶງສູດອອກມາ, ໃນຮູບແບບຂໍ້ຄວາມ.

ຕົວຢ່າງ:

ໃນ Basic

ຕົວຢ່າງຕໍ່ໄປນີ້ຈະສົ່ງຄືນອາເຣຂະໜາດ 3 ຄູນ 2 ທີ່ມີສູດໃນຊ່ວງ "A1:B3" (3 ແຖວ ຄູນ 2 ຄໍລຳ):


    arrFormula = oDoc.GetFormula("~.A1:B3")
  
ໃນ Python

    arrFormula = myDoc.GetFormula("~.A1:B3")
  

GetValue

ດຶງຄ່າທີ່ເກັບໄວ້ໃນຊ່ວງເຊວທີ່ລະບຸ ເປັນຄ່າດ່ຽວ, ອາເຣ 1 ມິຕິ ຫຼື 2 ມິຕິ. ຄ່າທັງໝົດຈະເປັນທັງຕົວເລກທົດສະນິຍົມ (double) ຫຼື ຂໍ້ຄວາມ.

ໄວຍາກອນ:

svc.GetValue(range: str): any

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຕ້ອງການດຶງຄ່າອອກມາ, ໃນຮູບແບບຂໍ້ຄວາມ.

ຕົວຢ່າງ:

ໃນ Basic

      arrValues = oDoc.GetValue("~.B1:C100")
  
ໃນ Python

    arrValues = myDoc.GetValue("~.B1:C100")
  
ໄອຄອນ ບັນທຶກ

ຖ້າເຊວບັນຈຸວັນທີ, ຈະສົ່ງຄືນຕົວເລກທີ່ກົງກັບວັນທີນັ້ນ. ເພື່ອແປງຄ່າຕົວເລກເປັນວັນທີໃນສະຄຣິບ Basic, ໃຫ້ໃຊ້ ຟັງຊັນ CDate ທີ່ມີມາພ້ອມກັບ Basic. ໃນສະຄຣິບ Python, ໃຫ້ໃຊ້ ຟັງຊັນ CDate ຈາກບໍລິການ Basic.


ImportFromCSVFile

ນຳເຂົ້າເນື້ອຫາຂອງໄຟລ໌ຂໍ້ຄວາມຮູບແບບ CSV ແລະ ວາງມັນລົງໃນເຊວປາຍທາງທີ່ລະບຸ.

ພື້ນທີ່ປາຍທາງຈະຖືກລຶບເນື້ອຫາ ແລະ ຮູບແບບທັງໝົດກ່ອນທີ່ຈະແຊກເນື້ອຫາຂອງໄຟລ໌ CSV. ຂະໜາດຂອງພື້ນທີ່ທີ່ຖືກປ່ຽນແປງຈະຖືກກຳນົດໂດຍເນື້ອຫາຂອງໄຟລ໌ນຳເຂົ້າ.

ເມທອດນີ້ສົ່ງຄືນຂໍ້ຄວາມທີ່ແທນຊ່ວງຂອງເຊວທີ່ຖືກປ່ຽນແປງ.

ໄວຍາກອນ:

svc.ImportFromCSVFile(filename: str, destinationcell: str, [filteroptions: str]): str

ພາຣາມິເຕີ:

filename: ລະບຸໄຟລ໌ທີ່ຈະເປີດ. ຕ້ອງເປັນໄປຕາມຮູບແບບການຕັ້ງຊື່ໄຟລ໌ຂອງ SF_FileSystem.FileNaming.

destinationcell: ເເຊວປາຍທາງທີ່ຈະແຊກຂໍ້ມູນທີ່ນຳເຂົ້າ, ໃນຮູບແບບຂໍ້ຄວາມ. ຖ້າລະບຸເປັນຊ່ວງ, ຈະພິຈາລະນາສະເພາະເຊວເທິງສຸດດ້ານຊ້າຍເທົ່ານັ້ນ.

filteroptions: ອາກິວເມນສຳລັບຕົວຊ່ວຍນຳເຂົ້າ CSV. ຕົວຊ່ວຍນຳເຂົ້າເລີ່ມຕົ້ນຈະຕັ້ງຄ່າດັ່ງນີ້:

ຕົວຢ່າງ:

ໃນ Basic

    oDoc.ImportFromCSVFile("C:\Temp\myCSVFile.csv", "SheetY.C5")
  
ໃນ Python

    myDoc.ImportFromCSVFile(r"C:\Temp\myCSVFile.csv", "SheetY.C5")
  
ໄອຄອນ ເຄັດລັບ

ເພື່ອຮຽນຮູ້ເພີ່ມເຕີມກ່ຽວກັບຕົວເລືອກຕົວຊ່ວຍນຳເຂົ້າ CSV, ກະລຸນາເບິ່ງທີ່ ໜ້າຊ່ວຍເຫຼືອຕົວເລືອກຕົວຊ່ວຍນຳເຂົ້າ CSV.


ImportFromDatabase

ນຳເຂົ້າເນື້ອຫາຂອງຕາຕະລາງຖານຂໍ້ມູນ, ຄຳຖາມ (query) ຫຼື ຊຸດຜົນລັດ, ເຊັ່ນ ຜົນລັດຈາກຄຳສັ່ງ SELECT SQL, ໂດຍແຊກລົງໃນເຊວປາຍທາງ.

ພື້ນທີ່ປາຍທາງຈະຖືກລຶບເນື້ອໃນ ແລະ ຮູບແບບທັງໝົດອອກກ່ອນທີ່ຈະແຊກເນື້ອໃນທີ່ນຳເຂົ້າມາ. ຂະໜາດຂອງພື້ນທີ່ທີ່ຖືກປັບປ່ຽນແມ່ນຂຶ້ນກັບເນື້ອໃນໃນຕາຕະລາງ ຫຼື ຄຳສັ່ງສອບຖາມທັງໝົດ.

ເມທອດນີ້ສົ່ງຄືນ True ເມື່ອການນຳເຂົ້າສຳເລັດ.

ໄວຍາກອນ:

svc.ImportFromDatabase(filename: str = "", registrationname: str = "", destinationcell: str = "", sqlcommand: str = "", directsql: bool): bool

ພາຣາມິເຕີ:

filename: ລະບຸໄຟລ໌ທີ່ຈະເປີດ. ມັນຕ້ອງເປັນໄປຕາມຮູບແບບ SF_FileSystem.FileNaming.

registrationname: ຊື່ທີ່ໃຊ້ໃນການຄົ້ນຫາຖານຂໍ້ມູນໃນທະບຽນຖານຂໍ້ມູນ. ອາກິວເມນນີ້ຈະຖືກລະເລີຍຫາກມີການລະບຸ filename.

destinationcell: ປາຍທາງຂອງຂໍ້ມູນທີ່ນຳເຂົ້າ, ໃນຮູບແບບຂໍ້ຄວາມ. ຫາກກຳນົດເປັນໄລຍະຂໍ້ມູນ, ຈະພິຈາລະນາສະເພາະຫ້ອງເທິງຊ້າຍສຸດເທົ່ານັ້ນ.

sqlcommand: ຊື່ຕາຕະລາງ ຫຼື ຄຳສັ່ງສອບຖາມ (ໂດຍບໍ່ມີເຄື່ອງໝາຍຄຳເວົ້າ ຫຼື ວົງເລັບກ້າມປູອ້ອມຮອບ) ຫຼື ຄຳສັ່ງ SELECT SQL ເຊິ່ງຊື່ຕາຕະລາງ ແລະ ຊື່ຟິວອາດຈະຖືກອ້ອມຮອບດ້ວຍວົງເລັບກ້າມປູ ຫຼື ເຄື່ອງໝາຍຄຳເວົ້າເພື່ອໃຫ້ອ່ານງ່າຍຂຶ້ນ.

directsql: ເມື່ອເປັນ True, ຄຳສັ່ງ SQL ຈະຖືກສົ່ງໄປຫາເຄື່ອງຈັກຖານຂໍ້ມູນໂດຍກົງໂດຍບໍ່ມີການວິເຄາະກ່ອນ. ຄ່າເລີ່ມຕົ້ນແມ່ນ False. ອາຄິວເມນນີ້ຈະຖືກລະເວັ້ນສຳລັບຕາຕະລາງ. ສຳລັບການສອບຖາມ, ຕົວເລືອກທີ່ໃຊ້ແມ່ນຕົວເລືອກທີ່ຕັ້ງໄວ້ຕອນກຳນົດການສອບຖາມ.

ຕົວຢ່າງ:

ໃນ Basic

    oDoc.ImportFromDatabase("C:\Temp\myDbFile.odb", , "SheetY.C5", "SELECT * FROM [Employees] ORDER BY [LastName]")
  
ໃນ Python

    myDoc.ImportFromDatabase(r"C:\Temp\myDbFile.odb", , "SheetY.C5", "SELECT * FROM [Employees] ORDER BY [LastName]")
  

ImportStylesFromFile

ວິທີການນີ້ຈະໂຫຼດທຸກຮູບແບບ (styles) ທີ່ຢູ່ໃນຕະກຸນຮູບແບບໜຶ່ງ ຫຼື ຫຼາຍຕະກຸນ ຈາກໄຟລ໌ທີ່ປິດຢູ່ ເຂົ້າສູ່ເອກະສານປັດຈຸບັນ. ເອກະສານປັດຈຸບັນຕ້ອງເປັນເອກະສານ Calc ຫຼື Writer.

ຈະຖືກນຳເຂົ້າພ້ອມກັນສະເໝີ:

ສົ່ງຄືນ True ຖ້ານຳເຂົ້າຮູບແບບສຳເລັດ.

ໄວຍາກອນ:

svc.ImportStylesFromFile(filename: str, families: str[1..*], overwrite = False): bool

ພາຣາມິເຕີ:

filename: ໄຟລ໌ທີ່ຈະໂຫຼດຮູບແບບ ໂດຍໃຊ້ຮູບແບບການຂຽນຂອງ FileSystem. ໄຟລ໌ດັ່ງກ່າວຄວນຈະເປັນປະເພດເອກະສານດຽວກັນກັບເອກະສານປັດຈຸບັນ.

families: ໜຶ່ງໃນຕະກຸນຮູບແບບທີ່ມີຢູ່ໃນເອກະສານປັດຈຸບັນ, ໂດຍລະບຸເປັນຂໍ້ຄວາມ (ຕົວອັກສອນໃຫຍ່-ນ້ອຍມີຄວາມໝາຍຕ່າງກັນ) ຫຼື ອາເຣຂອງຂໍ້ຄວາມ. ປະອາຄິວເມນນີ້ໃຫ້ຫວ່າງໄວ້ເພື່ອໂຫຼດທຸກຕະກຸນ.

overwrite: ເມື່ອເປັນ True, ຮູບແບບທີ່ມີຢູ່ອາດຈະຖືກຂຽນທັບ. ຄ່າເລີ່ມຕົ້ນແມ່ນ False.

ຕົວຢ່າງ:

ໃນ Basic

    oDoc.ImportStylesFromFile("C:\User\Documents\myFile.ods", "ParagraphStyles", True)
  
ໃນ Python

    doc.ImportStylesFromFile('C:\User\Documents\myFile.ods', ("ParagraphStyles",), False)
  

InsertSheet

ແຊກແຜ່ນງານຫວ່າງໃໝ່ໄວ້ກ່ອນແຜ່ນງານທີ່ມີຢູ່ ຫຼື ໄວ້ທ້າຍສຸດຂອງລາຍການແຜ່ນງານ.

ໄວຍາກອນ:

svc.InsertSheet(sheetname: str, [beforesheet: any]): bool

ພາຣາມິເຕີ:

sheetname: ຊື່ຂອງແຜ່ນງານໃໝ່.

beforesheet: ຊື່ (ຂໍ້ຄວາມ) ຫຼື ລຳດັບ (ຕົວເລກ, ເລີ່ມຈາກ 1) ຂອງແຜ່ນງານທີ່ຈະແຊກແຜ່ນງານໃໝ່ໄວ້ທາງໜ້າ. ອາຄິວເມນນີ້ເປັນທາງເລືອກ ແລະ ຄ່າເລີ່ມຕົ້ນແມ່ນຈະແຊກແຜ່ນງານໄວ້ໃນຕຳແໜ່ງສຸດທ້າຍ.

ຕົວຢ່າງ:

ຕົວຢ່າງຕໍ່ໄປນີ້ຈະແຊກແຜ່ນງານຫວ່າງໃໝ່ທີ່ຊື່ວ່າ "SheetX" ແລະ ວາງມັນໄວ້ທາງໜ້າ "SheetY":

ໃນ Basic

    oDoc.InsertSheet("SheetX", "SheetY")
  
ໃນ Python

    myDoc.InsertSheet("SheetX", "SheetY")
  

Intersect

ສົ່ງຄືນຂໍ້ຄວາມທີ່ແທນການທັບຊ້ອນກັນ (intersection) ລະຫວ່າງສອງຊ່ວງທີ່ນຳເຂົ້າ, ຫຼື ສົ່ງຄືນຂໍ້ຄວາມຫວ່າງຫາກບໍ່ມີການທັບຊ້ອນກັນ.

ໄວຍາກອນ:

svc.Intersect(range1:str, range2: str): str

ພາຣາມິເຕີ:

range1: ຂໍ້ຄວາມທີ່ຢູ່ຂອງໄລຍະຂໍ້ມູນ 1.

range2: ຂໍ້ຄວາມທີ່ຢູ່ຂອງໄລຍະຂໍ້ມູນ 2.

ຕົວຢ່າງ:

ຕົວຢ່າງຕໍ່ໄປນີ້ຈະຫາການທັບຊ້ອນກັນຂອງສອງຊ່ວງ, ແລະ ສົ່ງຄືນຊ່ວງທີ່ຢູ່ຮ່ວມກັນລະຫວ່າງທັງສອງ:

ໃນ Basic

    Dim commonrange As String
    commonrange = oDoc.Intersect("A1:D8", "C3:F4")
    Print commonrange ' ສະແດງ "$Sheet1.$C$3:$D$4"
  
ໃນ Python

    common_range = myDoc.Intersect("A1:D8", "C3:F4")
    print(common_range)  # ສົ່ງຜົນລັດ '$Sheet1.$C$3:$D$4' ໄປຫາ Python shell
  

MoveRange

ຍ້າຍຊ່ວງຕົ້ນທາງທີ່ລະບຸ ໄປຫາຊ່ວງເຊວປາຍທາງ. ເມທອດນີ້ສົ່ງຄືນຂໍ້ຄວາມທີ່ແທນຊ່ວງຂອງເຊວທີ່ຖືກປ່ຽນແປງ. ຂະໜາດຂອງພື້ນທີ່ທີ່ຖືກປ່ຽນແປງຈະຖືກກຳນົດໂດຍຂະໜາດຂອງພື້ນທີ່ຕົ້ນທາງ.

ໄວຍາກອນ:

svc.MoveRange(source: str, destination: str): str

ພາຣາມິເຕີ:

source: ໄລຍະຂໍ້ມູນຕົ້ນທາງຂອງຫ້ອງ, ໃນຮູບແບບຂໍ້ຄວາມ.

destination: ຫ້ອງປາຍທາງ, ໃນຮູບແບບຂໍ້ຄວາມ. ຫາກກຳນົດເປັນໄລຍະຂໍ້ມູນ, ຈະພິຈາລະນາຫ້ອງເທິງຊ້າຍສຸດເປັນປາຍທາງ.

ຕົວຢ່າງ:

ໃນ Basic

    oDoc.MoveRange("SheetX.A1:F10", "SheetY.C5")
  
ໃນ Python

    myDoc.MoveRange("SheetX.A1:F10", "SheetY.C5")
  

MoveSheet

ຍ້າຍແຜ່ນງານທີ່ມີຢູ່ ແລະ ວາງມັນໄວ້ກ່ອນແຜ່ນງານທີ່ລະບຸ ຫຼື ໄວ້ທ້າຍສຸດຂອງລາຍການແຜ່ນງານ.

ໄວຍາກອນ:

svc.MoveSheet(sheetname: str, [beforesheet: any]): bool

ພາຣາມິເຕີ:

sheetname: ຊື່ຂອງແຜ່ນງານທີ່ຕ້ອງການຍ້າຍ. ແຜ່ນງານນັ້ນຕ້ອງມີຢູ່ຈິງ ຖ້າບໍ່ດັ່ງນັ້ນຈະເກີດຂໍ້ຜິດພາດ (exception).

beforesheet: ຊື່ (ສະຕຣິງ) ຫຼື ດັດຊະນີ (ຕົວເລກ, ເລີ່ມຈາກ 1) ຂອງແຜ່ນງານທີ່ຈະວາງແຜ່ນງານຕົ້ນສະບັບໄວ້ກ່ອນໜ້າມັນ. ອາຄິວເມນນີ້ເປັນທາງເລືອກ ແລະ ພຶດຕິກຳເລີ່ມຕົ້ນແມ່ນການຍ້າຍແຜ່ນງານໄປໄວ້ຕຳແໜ່ງສຸດທ້າຍ.

ຕົວຢ່າງ:

ຕົວຢ່າງຂ້າງລຸ່ມນີ້ແມ່ນການຍ້າຍແຜ່ນງານ "SheetX" ທີ່ມີຢູ່ແລ້ວໄປວາງໄວ້ກ່ອນໜ້າ "SheetY":

ໃນ Basic

    oDoc.MoveSheet("SheetX", "SheetY")
  
ໃນ Python

    myDoc.MoveSheet("SheetX", "SheetY")
  

Offset

ສົ່ງຄືນຊ່ວງໃໝ່ (ໃນຮູບແບບສະຕຣິງ) ທີ່ຖືກເລື່ອນ (offset) ໄປຕາມຈຳນວນແຖວ ແລະ ຖັນທີ່ກຳນົດຈາກຊ່ວງທີ່ໃຫ້ມາ.

ວິທີການນີ້ມີການເຮັດວຽກຄືກັນກັບ ຟັງຊັນ Offset ຂອງ Calc ທີ່ມີຊື່ດຽວກັນ.

ໄວຍາກອນ:

svc.Offset(reference: str, rows: int = 0, columns: int = 0, [height: int], [width: int]): str

ພາຣາມິເຕີ:

reference: ຊ່ວງ (ໃນຮູບແບບສະຕຣິງ) ທີ່ວິທີການນີ້ຈະໃຊ້ເປັນບ່ອນອ້າງອີງເພື່ອດຳເນີນການເລື່ອນ (offset).

rows: ຈຳນວນແຖວທີ່ຊ່ວງເລີ່ມຕົ້ນຈະຖືກເລື່ອນຂຶ້ນ (ຄ່າລົບ) ຫຼື ເລື່ອນລົງ (ຄ່າບວກ). ໃຊ້ 0 (ຄ່າເລີ່ມຕົ້ນ) ເພື່ອໃຫ້ຢູ່ແຖວເກົ່າ.

columns: ຈຳນວນຖັນທີ່ຊ່ວງເລີ່ມຕົ້ນຈະຖືກເລື່ອນໄປທາງຊ້າຍ (ຄ່າລົບ) ຫຼື ເລື່ອນໄປທາງຂວາ (ຄ່າບວກ). ໃຊ້ 0 (ຄ່າເລີ່ມຕົ້ນ) ເພື່ອໃຫ້ຢູ່ຖັນເກົ່າ.

height: ຄວາມສູງແນວຕັ້ງສຳລັບພື້ນທີ່ທີ່ເລີ່ມຈາກຕຳແໜ່ງຊ່ວງໃໝ່. ໃຫ້ຂ້າມອາຄິວເມນນີ້ໄປຫາກບໍ່ຕ້ອງການປ່ຽນຂະໜາດແນວຕັ້ງ.

width: ຄວາມກວ້າງແນວນອນສຳລັບພື້ນທີ່ທີ່ເລີ່ມຈາກຕຳແໜ່ງຊ່ວງໃໝ່. ໃຫ້ຂ້າມອາຄິວເມນນີ້ໄປຫາກບໍ່ຕ້ອງການປ່ຽນຂະໜາດແນວນອນ.

ອາຄິວເມນ rows ແລະ columns ຕ້ອງບໍ່ເຮັດໃຫ້ແຖວ ຫຼື ຖັນເລີ່ມຕົ້ນເປັນສູນ ຫຼື ເປັນຄ່າລົບ.

ອາຄິວເມນ height ແລະ width ຕ້ອງບໍ່ເຮັດໃຫ້ຈຳນວນແຖວ ຫຼື ຖັນເປັນສູນ ຫຼື ເປັນຄ່າລົບ.

ຕົວຢ່າງ:

ໃນ Basic

    oDoc.Offset("A1", 2, 2)
    'SheetX.$C$3 (A1 ຖືກຍ້າຍລົງສອງແຖວ ແລະ ສອງຖັນ)
    oDoc.Offset("A1", 2, 2, 5, 6)
    'SheetX.$C$3:$H$7 (A1 ຖືກເລື່ອນລົງສອງແຖວ ແລະ ຖັນ ໂດຍມີຄວາມສູງ 5 ແຖວ ແລະ ຄວາມກວ້າງ 6 ຖັນ)
  
ໃນ Python

    myDoc.Offset("A1", 2, 2)
    myDoc.Offset("A1", 2, 2, 5, 6)
  

OpenRangeSelector

ເປີດກ່ອງໂຕ້ຕອບແບບ non-modal ທີ່ສາມາດໃຊ້ເພື່ອເລືອກຊ່ວງໃນເອກະສານ ແລະ ສົ່ງຄືນສະຕຣິງທີ່ບັນຈຸຊ່ວງທີ່ຖືກເລືອກ.

ໄອຄອນ ບັນທຶກ

ວິທີການນີ້ຈະເປີດກ່ອງໂຕ້ຕອບອັນດຽວກັນກັບທີ່ LibreOfficeDev ໃຊ້ເມື່ອມີການກົດປຸ່ມຫຍໍ້ (Shrink). ຕົວຢ່າງ: ກ່ອງໂຕ້ຕອບ Tools - Goal Seek ມີປຸ່ມຫຍໍ້ຢູ່ທາງເບື້ອງຂວາຂອງຊ່ອງ Formula cell.


ວິທີການນີ້ຈະບໍ່ປ່ຽນແປງການເລືອກໃນປັດຈຸບັນ.

ໄວຍາກອນ:

svc.OpenRangeSelector(opt title: str, opt selection: str, singlecell: bool = False, closeafterselect: bool = True): str

ພາຣາມິເຕີ:

title: ຊື່ຫົວຂໍ້ຂອງກ່ອງໂຕ້ຕອບ, ໃນຮູບແບບສະຕຣິງ.

selection: ຊ່ວງທາງເລືອກທີ່ຈະຖືກເລືອກໄວ້ກ່ອນໃນຕອນທີ່ສະແດງກ່ອງໂຕ້ຕອບ.

singlecell: ເມື່ອເປັນ True (ຄ່າເລີ່ມຕົ້ນ) ຈະອະນຸຍາດໃຫ້ເລືອກໄດ້ພຽງເຊລດຽວເທົ່ານັ້ນ. ເມື່ອເປັນ False ຈະອະນຸຍາດໃຫ້ເລືອກເປັນຊ່ວງໄດ້.

closeafterselect: ເມື່ອເປັນ True (ຄ່າເລີ່ມຕົ້ນ) ກ່ອງໂຕ້ຕອບຈະຖືກປິດທັນທີຫຼັງຈາກທີ່ມີການເລືອກ. ເມື່ອເປັນ False ຜູ້ໃຊ້ສາມາດປ່ຽນການເລືອກໄດ້ຫຼາຍຄັ້ງຕາມທີ່ຕ້ອງການ ແລ້ວຈຶ່ງປິດກ່ອງໂຕ້ຕອບດ້ວຍຕົນເອງ.

ຕົວຢ່າງ:

ໃນ Basic

    Dim sRange as String
    sRange = oDoc.OpenRangeSelector(Title := "Select a range")
  
ໃນ Python

    sRange = myDoc.OpenRangeSelector(title = "Select a range")
  

Printf

ສົ່ງຄືນສະຕຣິງທີ່ປ້ອນເຂົ້າ ຫຼັງຈາກປ່ຽນແທນຕົວອັກສອນໂທເຄັນ (token) ດ້ວຍຄ່າຂອງພວກມັນໃນຊ່ວງທີ່ກຳນົດ.

ວິທີການນີ້ຈະບໍ່ປ່ຽນແປງການເລືອກໃນປັດຈຸບັນ.

ໄອຄອນ ເຄັດລັບ

ວິທີການນີ້ສາມາດໃຊ້ເພື່ອດຶງເອົາພາກສ່ວນສະເພາະຂອງຊື່ຊ່ວງອອກມາໄດ້ຢ່າງວ່ອງໄວ ເຊັ່ນ: ຊື່ແຜ່ນງານ ຫຼື ຖັນ ແລະ ແຖວຂອງເຊລທຳອິດ ແລະ ນຳໃຊ້ພວກມັນເພື່ອສ້າງທີ່ຢູ່ຊ່ວງໃໝ່.


ໄວຍາກອນ:

svc.Printf(inputstr: str, range: str, tokencharacter: str = "%"): str

ພາຣາມິເຕີ:

inputstr: ສະຕຣິງທີ່ມີໂທເຄັນເຊິ່ງຈະຖືກປ່ຽນແທນດ້ວຍຄ່າທີ່ກົງກັນໃນ range.

range: ຊື່ຊ່ວງ (RangeName) ທີ່ຈະດຶງເອົາຄ່າອອກມາ. ຖ້າມັນມີຊື່ແຜ່ນງານ, ແຜ່ນງານນັ້ນຕ້ອງມີຢູ່ແທ້.

tokencharacter: ຕົວອັກສອນທີ່ໃຊ້ເພື່ອລະບຸໂທເຄັນ. ໂດຍເລີ່ມຕົ້ນ "%" ແມ່ນຕົວອັກສອນໂທເຄັນ. ໂທເຄັນຕໍ່ໄປນີ້ແມ່ນສາມາດໃຊ້ໄດ້:

ຕົວຢ່າງ:

ໃນ Basic

ຕົວຢ່າງຂ້າງລຸ່ມນີ້ດຶງເອົາແຕ່ລະອົງປະກອບຂອງ RangeName ທີ່ກຳນົດໃນ sRange ແລະ ນຳໃຊ້ພວກມັນເພື່ອສ້າງຂໍ້ຄວາມ.


    Dim sRange as String, sInputStr as String
    sRange = "Sheet1.A1:E10"
    sInputStr = "Sheet name: %S" & Chr(10) & _
                "First row: %R1" & Chr(10) & _
                "First column %C1" & Chr(10) & _
                "Last row %R2" & Chr(10) & _
                "Last column %C2"
    MsgBox oDoc.Printf(sInputStr, sRange)
  

ວິທີການ Printf ສາມາດໃຊ້ຮ່ວມກັບ SetFormula ເພື່ອສ້າງສູດຄິດໄລ່ໃນຫຼາຍໆເຊລ. ຕົວຢ່າງ: ສົມມຸດວ່າມີຕາຕະລາງທີ່ມີຄ່າຕົວເລກໃນຊ່ວງ "A1:E10" ເຊິ່ງຕ້ອງການສ້າງສູດເພື່ອລວມຄ່າໃນແຕ່ລະແຖວ ແລະ ວາງຜົນລັບໄວ້ໃນຊ່ວງ "F1:F10":


    Dim sFormula as String, sRange as String
    sRange = "A1:E10"
    ' ສັງເກດການນຳໃຊ້ຕົວອັກສອນ "$"
    sFormula = "=SUM($%C1%R1:$%C2%R1)"
    oDoc.SetFormula("F1:F10", oDoc.Printf(sFormula, sRange))
  
ໃນ Python

    sRange = "Sheet1.A1:E10"
    sInputStr = "Sheet name: %S\n" \
                "First row: %R1\n" \
                "First column %C1\n" \
                "Last row %R2\n" \
                "Last column %C2"
    bas = CreateScriptService("Basic")
    bas.MsgBox(myDoc.Printf(sInputStr, sRange))
  

    sRange = "A1:E10
    sFormula = "=SUM($%C1%R1:$%C2%R1)"
    myDoc.SetFormula("F1:F10", myDoc.Printf(sFormula, sRange))
  

PrintOut

ວິທີການນີ້ຈະສົ່ງເນື້ອໃນຂອງແຜ່ນງານທີ່ໃຫ້ມາໄປຍັງເຄື່ອງພິມເລີ່ມຕົ້ນ ຫຼື ເຄື່ອງພິມທີ່ກຳນົດໂດຍວິທີການ SetPrinter ຂອງບໍລິການ Document.

ສົ່ງຄືນ True ຖ້າການພິມແຜ່ນງານສຳເລັດ.

ໄວຍາກອນ:

svc.PrintOut(opt sheetname: str, pages: str = "", copies: num = 1): bool

ພາຣາມິເຕີ:

sheetname: ແຜ່ນງານທີ່ຈະພິມ, ຄ່າເລີ່ມຕົ້ນແມ່ນແຜ່ນງານທີ່ກຳລັງໃຊ້ຢູ່.

pages: ໜ້າທີ່ຈະພິມໃນຮູບແບບສະຕຣິງ, ຄືກັນກັບໃນສ່ວນຕິດຕໍ່ຜູ້ໃຊ້. ຕົວຢ່າງ: "1-4;10;15-18". ຄ່າເລີ່ມຕົ້ນແມ່ນທຸກໜ້າ.

copies: ຈຳນວນຊຸດທີ່ຈະພິມ. ຄ່າເລີ່ມຕົ້ນແມ່ນ 1.

ຕົວຢ່າງ:

ໃນ Basic

    If oDoc.PrintOut("SheetX", "1-4;10;15-18", Copies := 2) Then
        ' ...
    End If
  
ໃນ Python

    if doc.PrintOut('SheetX', copies=3, pages='45-88'):
        # ...
  

RemoveDuplicates

ລຶບແຖວທີ່ຊ້ຳກັນອອກຈາກຊ່ວງທີ່ກຳນົດ. ການປຽບທຽບເພື່ອພິຈາລະນາວ່າແຖວໃດຊ້ຳກັນແມ່ນອີງຕາມຊຸດຍ່ອຍຂອງຖັນໃນຊ່ວງນັ້ນ.

ວິທີການນີ້ສົ່ງຄືນສະຕຣິງທີ່ບັນຈຸຊ່ວງຜົນລັບ.

ໄອຄອນ ບັນທຶກ

ການລຶບແຖວທີ່ຊ້ຳກັນແມ່ນເລີ່ມຈາກແຖວທຳອິດໃນຊ່ວງແລ້ວໄລ່ລົງໄປຂ້າງລຸ່ມ, ໝາຍຄວາມວ່າຖ້າມີສອງແຖວ ຫຼື ຫຼາຍກວ່ານັ້ນຊ້ຳກັນ, ຈະມີພຽງແຖວທຳອິດເທົ່ານັ້ນທີ່ຖືກເກັບໄວ້.


ໄວຍາກອນ:

svc.RemoveDuplicates(range: str, opt columns: int[0..*], header: bool = False, casesensitive: bool = False, mode: str = "COMPACT"): str

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຈະລຶບແຖວຊ້ຳອອກ, ໃນຮູບແບບສະຕຣິງ.

columns: ອາເຣທີ່ບັນຈຸເລກຖັນເພື່ອລະບຸວ່າຈະໃຊ້ຖັນໃດໃນການພິຈາລະນາວ່າແຖວຊ້ຳກັນຫຼືບໍ່. ຖ້າປ່ອຍອາຄິວເມນນີ້ວ່າງໄວ້, ຈະໃຊ້ພຽງຖັນທຳອິດເທົ່ານັ້ນ. ລາຍການໃນອາເຣນີ້ຕ້ອງຢູ່ໃນຊ່ວງລະຫວ່າງ 1 ຫາ ຄວາມກວ້າງຂອງຊ່ວງ.

header: ກຳນົດວ່າແຖວທຳອິດເປັນແຖວຫົວຂໍ້ຫຼືບໍ່ (ຄ່າເລີ່ມຕົ້ນ = False).

casesensitive: ກຳນົດວ່າການປຽບທຽບສະຕຣິງຈະຕ້ອງກົງກັນທັງຕົວພິມໃຫຍ່ ແລະ ຕົວພິມນ້ອຍຫຼືບໍ່ (ຄ່າເລີ່ມຕົ້ນ = False).

mode: ກຳນົດວ່າຈະເຮັດແນວໃດກັບແຖວທີ່ຊ້ຳກັນ. ຖ້າ mode = "CLEAR" ແຖວທີ່ຊ້ຳຈະຖືກລຶບອອກຈາກແຜ່ນງານໂດຍປ່ອຍໃຫ້ເຊລວ່າງໄວ້. ຖ້າ mode = "COMPACT" ແຖວທີ່ຊ້ຳຈະຖືກລຶບອອກ ແລະ ແຖວທີ່ວ່າງຈະຖືກບີບຂຶ້ນເທິງ (ຄ່າເລີ່ມຕົ້ນ = "COMPACT").

ຕົວຢ່າງ:

ໃນ Basic

    ' ລຶບແຖວທີ່ຊ້ຳກັນ ບ່ອນທີ່ມີຄ່າໃນຖັນ A ຊ້ຳກັນ
    ' ສັງເກດວ່າອາຄິວເມນທາງເລືອກທັງໝົດຈະໃຊ້ຄ່າເລີ່ມຕົ້ນຂອງພວກມັນ
    oDoc.RemoveDuplicates("A1:B10")
    ' ລຶບແຖວທີ່ຊ້ຳກັນ ໂດຍພິຈາລະນາວ່າແຖວທຳອິດມີຫົວຂໍ້
    ' ໃຊ້ຖັນ A ແລະ B ເພື່ອພິຈາລະນາວ່າແຖວໃດຊ້ຳກັນ
    ' ເຊລທີ່ມີຄ່າຊ້ຳກັນຈະຖືກປ່ອຍໃຫ້ວ່າງໄວ້
    oDoc.RemoveDuplicates("A1:D10", columns := Array(1, 2), header := True, mode := "CLEAR")
  
ໃນ Python

    myDoc.RemoveDuplicates("A1:B10")
    myDoc.RemoveDuplicates("A1:D10", columns = (1, 2), header = True, mode = "CLEAR")
  

RemoveSheet

ລຶບແຜ່ນງານທີ່ມີຢູ່ແລ້ວອອກຈາກເອກະສານ.

ໄວຍາກອນ:

svc.RemoveSheet(sheetname: str): bool

ພາຣາມິເຕີ:

sheetname: ຊື່ຂອງແຜ່ນງານທີ່ຈະລຶບອອກ.

ຕົວຢ່າງ:

ໃນ Basic

    oDoc.RemoveSheet("SheetY")
  
ໃນ Python

    myDoc.RemoveSheet("SheetY")
  

RenameSheet

ປ່ຽນຊື່ແຜ່ນງານທີ່ໃຫ້ມາ ແລະ ສົ່ງຄືນ True ຖ້າສຳເລັດ.

ໄວຍາກອນ:

svc.RenameSheet(sheetname: str, newname: str): bool

ພາຣາມິເຕີ:

sheetname: ຊື່ຂອງແຜ່ນງານທີ່ຈະປ່ຽນຊື່.

newname: ຊື່ໃໝ່ຂອງແຜ່ນງານ. ມັນຕ້ອງເປັນຊື່ທີ່ຍັງບໍ່ທັນມີເທື່ອ.

ຕົວຢ່າງ:

ຕົວຢ່າງນີ້ປ່ຽນຊື່ແຜ່ນງານທີ່ກຳລັງໃຊ້ຢູ່ເປັນ "SheetY":

ໃນ Basic

    oDoc.RenameSheet("~", "SheetY")
  
ໃນ Python

    mydoc.RenameSheet("~", "SheetY")
  

SetArray

ເກັບຄ່າທີ່ໃຫ້ມາ ໂດຍເລີ່ມຈາກເຊລເປົ້າໝາຍທີ່ກຳນົດ. ພື້ນທີ່ທີ່ຖືກອັບເດດຈະຂະຫຍາຍຕົວມັນເອງຈາກເຊລເປົ້າໝາຍ ຫຼື ຈາກມຸມເທິງຊ້າຍຂອງຊ່ວງທີ່ໃຫ້ມາ ເພື່ອໃຫ້ຮອງຮັບຂະໜາດຂອງອາຄິວເມນ value ທີ່ປ້ອນເຂົ້າ. ເວກເຕີ (Vectors) ຈະຖືກຂະຫຍາຍໃນແນວຕັ້ງສະເໝີ.

ວິທີການນີ້ສົ່ງຄືນສະຕຣິງທີ່ສະແດງເຖິງພື້ນທີ່ທີ່ຖືກປ່ຽນແປງໃນຮູບແບບຂອງຊ່ວງເຊລ.

ໄວຍາກອນ:

svc.SetArray(targetcell: str, value: any): str

ພາຣາມິເຕີ:

targetcell: ເຊລ ຫຼື ຊ່ວງໃນຮູບແບບສະຕຣິງທີ່ຈະເລີ່ມເກັບຄ່າທີ່ໃຫ້ມາ.

value: ຄ່າສະກາລາ (scalar), ເວກເຕີ (vector) ຫຼື ອາເຣ (array) (ໃນ Python ແມ່ນລິສ ຫຼື ທຸບໂພ ທີ່ມີໜຶ່ງ ຫຼື ສອງມິຕິ) ທີ່ມີຄ່າໃໝ່ທີ່ຈະເກັບເລີ່ມຈາກເຊລເປົ້າໝາຍ ຫຼື ຈາກມຸມເທິງຊ້າຍຂອງຊ່ວງ (ຖ້າ targetcell ເປັນຊ່ວງ). ຄ່າໃໝ່ຕ້ອງເປັນສະຕຣິງ, ຕົວເລກ ຫຼື ວັນທີ. ປະເພດອື່ນໆຈະເຮັດໃຫ້ເຊລທີ່ກ່ຽວຂ້ອງຖືກປ່ອຍໃຫ້ວ່າງ.

ຕົວຢ່າງ:

ໃນ Basic

ຕົວຢ່າງຕໍ່ໄປນີ້ໃຊ້ ຟັງຊັນ DimArray ທີ່ມີມາໃຫ້ເພື່ອສ້າງອາເຣ ແລ້ວເກັບມັນໄວ້ໃນເຊລ "A1":


    Dim arrData as Variant
    arrData = DimArray(2, 1)
    arrData(0, 0) = 1 : arrData(1, 0) = 2 : arrData(2, 0) = 3
    arrData(0, 1) = "One" : arrData(1, 1) = "Two" : arrData(2, 1) = "Three"
    oDoc.SetArray("Sheet1.A1", arrData)
  

ຕົວຢ່າງນີ້ໃຊ້ວິທີການ RangeInit ຂອງ ບໍລິການ ScriptForge Array ເພື່ອສ້າງອາເຣທີ່ມີຄ່າ ເຊິ່ງຈະຖືກເກັບໄວ້ເລີ່ມຈາກເຊລ "A1" ລົງໄປຂ້າງລຸ່ມ.


    'ຕື່ມຂໍ້ມູນໃນຖັນທີ 1 ດ້ວຍຄ່າຕັ້ງແຕ່ 1 ຫາ 1000
    oDoc.SetArray("Sheet1.A1", SF_Array.RangeInit(1, 1000))
  
ໃນ Python

    arrData = ((1, "One"), (2, "Two"), (3, "Three"))
    myDoc.SetArray("Sheet1.A1", arrData)
  

    myDoc.SetArray("Sheet1.A1", tuple(i + 1 for i in range(1000)))
  
ໄອຄອນ ເຄັດລັບ

ເພື່ອວາງເນື້ອໃນທັງໝົດຂອງອາເຣລົງໃນແຜ່ນງານ, ໃຫ້ໃຊ້ SetArray. ເພື່ອວາງເນື້ອໃນຂອງອາເຣສະເພາະພາຍໃນຂອບເຂດຂອງຊ່ວງເຊລເປົ້າໝາຍ, ໃຫ້ໃຊ້ SetValue.


SetCellStyle

ນຳໃຊ້ຮູບແບບເຊລ (cell style) ທີ່ກຳນົດໃຫ້ກັບຊ່ວງເປົ້າໝາຍ. ທັງໝົດຊ່ວງຈະຖືກອັບເດດ ແລະ ສ່ວນທີ່ເຫຼືອຂອງແຜ່ນງານຈະບໍ່ຖືກແຕະຕ້ອງ. ຖ້າບໍ່ມີຮູບແບບເຊລນັ້ນຢູ່, ຈະມີການແຈ້ງເຕືອນຂໍ້ຜິດພາດ.

ວິທີການນີ້ສົ່ງຄືນສະຕຣິງທີ່ສະແດງເຖິງພື້ນທີ່ທີ່ຖືກປ່ຽນແປງໃນຮູບແບບຂອງຊ່ວງເຊລ.

ໄວຍາກອນ:

svc.SetCellStyle(targetrange: str, style: str, opt filterformula: str, opt filterscope: str): str

ພາຣາມິເຕີ:

targetrange: ຊ່ວງທີ່ຈະນຳໃຊ້ຮູບແບບ, ໃນຮູບແບບສະຕຣິງ.

style: ຊື່ຂອງຮູບແບບເຊລທີ່ຈະນຳໃຊ້.

filterformula: ສູດ Calc ທີ່ຈະຖືກນຳໃຊ້ກັບຊ່ວງທີ່ລະບຸເພື່ອ ກຳນົດວ່າເຊວໃດຈະໄດ້ຮັບຜົນກະທົບ. ສູດທີ່ລະບຸຕ້ອງສົ່ງຄືນຄ່າ True ຫຼື False. ຖ້າບໍ່ໄດ້ລະບຸອາກິວເມນນີ້, ເຊວທັງໝົດໃນຊ່ວງຈະໄດ້ຮັບຜົນກະທົບ.

filterscope: ກຳນົດວ່າ filterformula ຈະຖືກຂະຫຍາຍໄປຍັງຊ່ວງທີ່ລະບຸແນວໃດ. ອາກິວເມນນີ້ແມ່ນຈຳເປັນຕ້ອງລະບຸ ຫາກມີການລະບຸ filterformula. ຄ່າທີ່ຍອມຮັບມີດັ່ງນີ້:

ຕົວຢ່າງ:

ໃນ Basic

    oDoc.SetCellStyle("A1:J1", "Heading 1")
    oDoc.SetCellStyle("A2:J100", "Neutral")
  
ໃນ Python

    myDoc.SetCellStyle("A1:J1", "Heading 1")
    myDoc.SetCellStyle("A2:J100", "Neutral")
  
ໄອຄອນ ເຄັດລັບ

ໃຫ້ອ້າງອີງເຖິງເອກະສານຂອງວິທີການ ClearAll ສຳລັບຕົວຢ່າງການນຳໃຊ້ອາຄິວເມນ filterformula ແລະ filterscope.


SetFormula

ແຊກສູດ (ຫຼື ອາເຣຂອງສູດ) ທີ່ໃຫ້ມາລົງໃນຊ່ວງທີ່ກຳນົດ. ຂະໜາດຂອງພື້ນທີ່ທີ່ຖືກປ່ຽນແປງຈະເທົ່າກັບຂະໜາດຂອງຊ່ວງ.

ວິທີການນີ້ສົ່ງຄືນສະຕຣິງທີ່ສະແດງເຖິງພື້ນທີ່ທີ່ຖືກປ່ຽນແປງໃນຮູບແບບຂອງຊ່ວງເຊລ.

ໄວຍາກອນ:

svc.SetFormula(targetrange: str, formula: any): str

ພາຣາມິເຕີ:

targetrange: ຊ່ວງທີ່ຈະແຊກສູດ, ໃນຮູບແບບສະຕຣິງ.

formula: ສະຕຣິງ, ເວກເຕີ ຫຼື ອາເຣຂອງສະຕຣິງທີ່ມີສູດໃໝ່ສຳລັບແຕ່ລະເຊລໃນຊ່ວງເປົ້າໝາຍ.

ທັງໝົດຊ່ວງຈະຖືກອັບເດດ ແລະ ສ່ວນທີ່ເຫຼືອຂອງແຜ່ນງານຈະບໍ່ມີການປ່ຽນແປງ.

ຖ້າສູດທີ່ໃຫ້ມາເປັນສະຕຣິງ, ສູດດຽວນັ້ນຈະຖືກວາງລົງໃນທົ່ວຊ່ວງ ໂດຍມີການປັບການອ້າງອີງແບບສຳພັດ (relative references) ໃຫ້ອັດຕະໂນມັດ.

ຖ້າຂະໜາດຂອງ formula ນ້ອຍກວ່າຂະໜາດຂອງ targetrange, ເຊລທີ່ເຫຼືອຈະຖືກປ່ອຍໃຫ້ວ່າງ.

ຖ້າຂະໜາດຂອງ formula ໃຫຍ່ກວ່າຂະໜາດຂອງ targetrange, ສູດຈະຖືກຄັດລອກພຽງບາງສ່ວນຈົນກວ່າຈະເຕັມຂະໜາດຂອງ targetrange.

ເວກເຕີ (Vectors) ຈະຖືກຂະຫຍາຍໃນແນວຕັ້ງສະເໝີ, ຍົກເວັ້ນໃນກໍລະນີທີ່ targetrange ມີຄວາມສູງພຽງແຕ່ 1 ແຖວ.

ໄອຄອນ ບັນທຶກ

ຟັງຊັນ Calc ທີ່ໃຊ້ໃນອາຄິວເມນ formula ຕ້ອງຂຽນເປັນຊື່ພາສາອັງກິດ. ສາມາດເຂົ້າເບິ່ງໜ້າ Wiki List of Calc Functions ເພື່ອເບິ່ງລາຍຊື່ຟັງຊັນ Calc ທັງໝົດເປັນພາສາອັງກິດ.


ຕົວຢ່າງ:

ໃນ Basic

    oDoc.SetFormula("A1", "=A2")
    'ເວກເຕີແນວນອນ, ບາງສ່ວນວ່າງ
    oDoc.SetFormula("A1:F1", Array("=A2", "=B2", "=C2+10"))
    'D2 ມີສູດ "=H2"
    oDoc.SetFormula("A1:D2", "=E1")
  
ໃນ Python

    myDoc.SetFormula("A1", "=A2")
    myDoc.SetFormula("A1:F1", ("=A2", "=B2", "=C2+10"))
    myDoc.SetFormula("A1:D2", "=E1")
  

SetValue

ເກັບຄ່າທີ່ໃຫ້ມາລົງໃນຊ່ວງທີ່ກຳນົດ. ຂະໜາດຂອງພື້ນທີ່ທີ່ຖືກປ່ຽນແປງຈະເທົ່າກັບຂະໜາດຂອງຊ່ວງເປົ້າໝາຍ.

ວິທີການນີ້ສົ່ງຄືນສະຕຣິງທີ່ສະແດງເຖິງພື້ນທີ່ທີ່ຖືກປ່ຽນແປງໃນຮູບແບບຂອງຊ່ວງເຊລ.

ໄວຍາກອນ:

svc.SetValue(targetrange: str, value: any): str

ພາຣາມິເຕີ:

targetrange: ຊ່ວງທີ່ຈະເກັບຄ່າທີ່ໃຫ້ມາ, ໃນຮູບແບບສະຕຣິງ.

value: ຄ່າສະກາລາ (scalar), ເວກເຕີ (vector) ຫຼື ອາເຣ (array) ທີ່ມີຄ່າໃໝ່ສຳລັບແຕ່ລະເຊລໃນຊ່ວງ. ຄ່າໃໝ່ຕ້ອງເປັນສະຕຣິງ, ຕົວເລກ ຫຼື ວັນທີ. ປະເພດອື່ນໆຈະເຮັດໃຫ້ເຊລທີ່ກ່ຽວຂ້ອງຖືກປ່ອຍໃຫ້ວ່າງ.

ທັງໝົດຊ່ວງຈະຖືກອັບເດດ ແລະ ສ່ວນທີ່ເຫຼືອຂອງແຜ່ນງານຈະບໍ່ມີການປ່ຽນແປງ. ຖ້າຂະໜາດຂອງ value ນ້ອຍກວ່າຂະໜາດຂອງ targetrange, ເຊລທີ່ເຫຼືອຈະຖືກປ່ອຍໃຫ້ວ່າງ.

ຖ້າຂະໜາດຂອງ value ໃຫຍ່ກວ່າຂະໜາດຂອງ targetrange, ຄ່າ value ຈະຖືກຄັດລອກພຽງບາງສ່ວນຈົນກວ່າຈະເຕັມຂະໜາດຂອງ targetrange.

ເວກເຕີ (Vectors) ຈະຖືກຂະຫຍາຍໃນແນວຕັ້ງ, ຍົກເວັ້ນໃນກໍລະນີທີ່ targetrange ມີຄວາມສູງພຽງແຕ່ 1 ແຖວ.

ຕົວຢ່າງ:

ໃນ Basic

    oDoc.SetValue("A1", 2)
    'ຂ້າງລຸ່ມນີ້ອາເຣ Value ນ້ອຍກວ່າ TargetRange (ເຊລທີ່ເຫຼືອຈະຖືກປ່ອຍໃຫ້ວ່າງ)
    oDoc.SetValue("A1:F1", Array(1, 2, 3))
    'ຂ້າງລຸ່ມນີ້ Value ແລະ TargetRange ມີຂະໜາດເທົ່າກັນ
    oDoc.SetValue("A1:D2", SF_Array.AppendRow(Array(1, 2, 3, 4), Array(5, 6, 7, 8)))
  

ຖ້າທ່ານຕ້ອງການຕື່ມຂໍ້ມູນລົງໃນແຖວດຽວ, ທ່ານສາມາດໃຊ້ຟັງຊັນ Offset. ໃນຕົວຢ່າງຂ້າງລຸ່ມນີ້, ສົມມຸດວ່າ arrData ເປັນອາເຣໜຶ່ງມິຕິ:


    Dim firstCell As String : firstCell = "A1"
    Dim lenArray As Integer : lenArray = UBound(arrData) - LBound(arrData) + 1
    Dim newRange As String : newRange = oDoc.Offset(firstCell, width = lenArray)
    oDoc.SetValue(newRange, arrData)
  
ໃນ Python

    myDoc.SetValue("A1", 2)
    myDoc.SetValue("A1:F1", (1, 2, 3))
    myDoc.SetValue("A1:D2", ((1, 2, 3, 4), (5, 6, 7, 8)))
  

    firstCell = "A1"
    newRange = doc.Offset(firstCell, width = len(arrData))
    doc.SetValue(newRange, arrData)
  

ShiftDown

ຍ້າຍຊ່ວງເຊລທີ່ກຳນົດລົງໄປຂ້າງລຸ່ມ ໂດຍການແຊກແຖວວ່າງ. ການເລືອກໃນປັດຈຸບັນຈະບໍ່ໄດ້ຮັບຜົນກະທົບ.

ຂຶ້ນກັບຄ່າຂອງອາຄິວເມນ wholerow, ແຖວທີ່ແຊກເຂົ້າໄປສາມາດກວມເອົາພຽງແຕ່ຄວາມກວ້າງຂອງຊ່ວງທີ່ກຳນົດ ຫຼື ກວມເອົາທຸກຖັນໃນແຖວນັ້ນ.

ວິທີການນີ້ສົ່ງຄືນສະຕຣິງທີ່ສະແດງເຖິງຕຳແໜ່ງໃໝ່ຂອງຊ່ວງເລີ່ມຕົ້ນ.

ໄອຄອນ ບັນທຶກ

ຖ້າຊ່ວງທີ່ຖືກຍ້າຍອອກໄປນອກຂອບຂອງແຜ່ນງານ, ຈະບໍ່ມີຫຍັງເກີດຂຶ້ນ.


ໄວຍາກອນ:

svc.ShiftDown(range: str, wholerow: bool = False, opt rows: int): str

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຈະແຊກແຖວໄວ້ຂ້າງເທິງມັນ, ໃນຮູບແບບສະຕຣິງ.

wholerow: ຖ້າຕັ້ງເປັນ False (ຄ່າເລີ່ມຕົ້ນ), ຄວາມກວ້າງຂອງແຖວທີ່ແຊກຈະເທົ່າກັບຄວາມກວ້າງຂອງ range ທີ່ກຳນົດ. ຖ້າບໍ່ດັ່ງນັ້ນ, ແຖວທີ່ແຊກຈະກວມເອົາທຸກຖັນໃນແຜ່ນງານ.

rows: ຈຳນວນແຖວທີ່ຈະແຊກ. ຄ່າເລີ່ມຕົ້ນແມ່ນຄວາມສູງຂອງ range ຕົ້ນສະບັບ. ຈຳນວນແຖວຕ້ອງເປັນຕົວເລກບວກ.

ຕົວຢ່າງ:

ໃນ Basic

    ' ຍ້າຍຊ່ວງ "A3:D3" ລົງໄປໜຶ່ງແຖວ; ມີຜົນກະທົບສະເພາະຖັນ A ຫາ D
    oDoc.ShiftDown("A3:D3")
    ' ແຖວທີ່ແຊກເຂົ້າໄປແມ່ນກວມເອົາທຸກຖັນໃນແຜ່ນງານ
    oDoc.ShiftDown("A3:D3", WholeRow := True)
    ' ຍ້າຍຊ່ວງ "A3:D3" ລົງໄປຫ້າແຖວ
    oDoc.ShiftDown("A3:D3", Rows := 5)
    ' ຍ້າຍຊ່ວງ "A3:D10" ລົງໄປສອງແຖວ ແລະ ສະແດງຕຳແໜ່ງໃໝ່ຂອງຊ່ວງຕົ້ນສະບັບ
    Dim sNewRange as String
    sNewRange = oDoc.ShiftDown("A3:D10", Rows := 2)
    MsgBox sNewRange   ' $Sheet1.$A$5:$D$12
  
ໃນ Python

    myDoc.ShiftDown("A3:D3")
    myDoc.ShiftDown("A3:D3", wholerow = True)
    myDoc.ShiftDown("A3:D3", rows = 5)
    sNewRange = myDoc.ShiftDown("A3:D10", rows = 2)
    bas = CreateScriptService("Basic")
    bas.MsgBox(sNewRange)
  

ShiftLeft

ລຶບຖັນທາງຊ້າຍສຸດຂອງຊ່ວງທີ່ກຳນົດ ແລະ ຍ້າຍເຊລທັງໝົດທີ່ຢູ່ທາງຂວາຂອງຊ່ວງນັ້ນໄປທາງຊ້າຍ. ການເລືອກໃນປັດຈຸບັນຈະບໍ່ໄດ້ຮັບຜົນກະທົບ.

ຂຶ້ນກັບຄ່າຂອງອາຄິວເມນ wholecolumn, ຖັນທີ່ຖືກລຶບສາມາດກວມເອົາພຽງແຕ່ຄວາມສູງຂອງຊ່ວງທີ່ກຳນົດ ຫຼື ກວມເອົາທຸກແຖວໃນຖັນນັ້ນ.

ວິທີການນີ້ສົ່ງຄືນສະຕຣິງທີ່ສະແດງເຖິງຕຳແໜ່ງຂອງສ່ວນທີ່ເຫຼືອຂອງຊ່ວງເລີ່ມຕົ້ນ. ຖ້າເຊລທັງໝົດໃນຊ່ວງຕົ້ນສະບັບຖືກລຶບໝົດ, ຈະສົ່ງຄືນເປັນສະຕຣິງວ່າງ.

ໄວຍາກອນ:

svc.ShiftLeft(range: str, wholecolumn: bool = False, opt columns: int): str

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຈະລຶບເຊລອອກ, ໃນຮູບແບບສະຕຣິງ.

wholecolumn: ຖ້າຕັ້ງເປັນ False (ຄ່າເລີ່ມຕົ້ນ), ຄວາມສູງຂອງຖັນທີ່ຖືກລຶບຈະເທົ່າກັບຄວາມສູງຂອງ range ທີ່ກຳນົດ. ຖ້າບໍ່ດັ່ງນັ້ນ, ຖັນທີ່ລຶບຈະກວມເອົາທຸກແຖວໃນແຜ່ນງານ.

columns: ຈຳນວນຖັນທີ່ຈະລຶບອອກຈາກ range ທີ່ກຳນົດ. ຄ່າເລີ່ມຕົ້ນແມ່ນຄວາມກວ້າງຂອງ range ຕົ້ນສະບັບ, ເຊິ່ງເປັນຄ່າສູງສຸດຂອງອາຄິວເມນນີ້ຄືກັນ.

ຕົວຢ່າງ:

ໃນ Basic

    ' ລຶບຊ່ວງ "B3:B6"; ຍ້າຍເຊລທັງໝົດທີ່ຢູ່ທາງຂວາໄປທາງຊ້າຍ
    oDoc.ShiftLeft("B3:B6")
    ' ລຶບຖັນທຳອິດໃນຊ່ວງ "A3:D6"
    oDoc.ShiftLeft("A3:D6", Columns := 1)
    ' ຖັນທີ່ຖືກລຶບ (A ຫາ D) ແມ່ນກວມເອົາທຸກແຖວໃນແຜ່ນງານ
    oDoc.ShiftLeft("A3:D6", WholeColumn := True)
  
ໃນ Python

    myDoc.ShiftLeft("B3:B6")
    myDoc.ShiftLeft("A3:D6", Columns = 1)
    myDoc.ShiftLeft("A3:D6", WholeColumn = True)
  

ShiftUp

ລຶບແຖວເທິງສຸດຂອງຊ່ວງທີ່ກຳນົດ ແລະ ຍ້າຍເຊລທັງໝົດທີ່ຢູ່ລຸ່ມຊ່ວງນັ້ນຂຶ້ນໄປທາງເທິງ. ການເລືອກໃນປັດຈຸບັນຈະບໍ່ໄດ້ຮັບຜົນກະທົບ.

ຂຶ້ນກັບຄ່າຂອງອາຄິວເມນ wholerow, ແຖວທີ່ຖືກລຶບສາມາດກວມເອົາພຽງແຕ່ຄວາມກວ້າງຂອງຊ່ວງທີ່ກຳນົດ ຫຼື ກວມເອົາທຸກຖັນໃນແຖວນັ້ນ.

ວິທີການນີ້ສົ່ງຄືນສະຕຣິງທີ່ສະແດງເຖິງຕຳແໜ່ງຂອງສ່ວນທີ່ເຫຼືອຂອງຊ່ວງເລີ່ມຕົ້ນ. ຖ້າເຊລທັງໝົດໃນຊ່ວງຕົ້ນສະບັບຖືກລຶບໝົດ, ຈະສົ່ງຄືນເປັນສະຕຣິງວ່າງ.

ໄວຍາກອນ:

svc.ShiftUp(range: str, wholerow: bool = False, opt rows: int): str

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຈະລຶບເຊລອອກ, ໃນຮູບແບບສະຕຣິງ.

wholerow: ຖ້າຕັ້ງເປັນ False (ຄ່າເລີ່ມຕົ້ນ), ຄວາມກວ້າງຂອງແຖວທີ່ຖືກລຶບຈະເທົ່າກັບຄວາມກວ້າງຂອງ range ທີ່ກຳນົດ. ຖ້າບໍ່ດັ່ງນັ້ນ, ແຖວທີ່ລຶບຈະກວມເອົາທຸກຖັນໃນແຜ່ນງານ.

rows: ຈຳນວນແຖວທີ່ຈະລຶບອອກຈາກ range ທີ່ກຳນົດ. ຄ່າເລີ່ມຕົ້ນແມ່ນຄວາມສູງຂອງ range ຕົ້ນສະບັບ, ເຊິ່ງເປັນຄ່າສູງສຸດຂອງອາຄິວເມນນີ້ຄືກັນ.

ຕົວຢ່າງ:

ໃນ Basic

    ' ລຶບຊ່ວງ "A3:D3"; ຍ້າຍເຊລທັງໝົດທີ່ຢູ່ລຸ່ມມັນຂຶ້ນມາທາງເທິງໜຶ່ງແຖວ
    oDoc.ShiftUp("A3:D3")
    ' ລຶບແຖວທຳອິດໃນຊ່ວງ "A3:D6"
    oDoc.ShiftUp("A3:D6", Rows := 1)
    ' ແຖວທີ່ຖືກລຶບແມ່ນກວມເອົາທຸກຖັນໃນແຜ່ນງານ
    oDoc.ShiftUp("A3:D6", WholeRow := True)
  
ໃນ Python

    myDoc.ShiftUp("A3:D3")
    myDoc.ShiftUp("A3:D6", rows = 1)
    myDoc.ShiftUp("A3:D6", wholerow = True)
  

ShiftRight

ຍ້າຍຊ່ວງເຊລທີ່ກຳນົດໄປທາງຂວາ ໂດຍການແຊກຖັນວ່າງ. ການເລືອກໃນປັດຈຸບັນຈະບໍ່ໄດ້ຮັບຜົນກະທົບ.

ຂຶ້ນກັບຄ່າຂອງອາຄິວເມນ wholecolumn, ຖັນທີ່ແຊກເຂົ້າໄປສາມາດກວມເອົາພຽງແຕ່ຄວາມສູງຂອງຊ່ວງທີ່ກຳນົດ ຫຼື ກວມເອົາທຸກແຖວໃນຖັນນັ້ນ.

ວິທີການນີ້ສົ່ງຄືນສະຕຣິງທີ່ສະແດງເຖິງຕຳແໜ່ງໃໝ່ຂອງຊ່ວງເລີ່ມຕົ້ນ.

ໄອຄອນ ບັນທຶກ

ຖ້າຊ່ວງທີ່ຖືກຍ້າຍອອກໄປນອກຂອບຂອງແຜ່ນງານ, ຈະບໍ່ມີຫຍັງເກີດຂຶ້ນ.


ໄວຍາກອນ:

svc.ShiftRight(range: str, wholecolumn: bool = False, opt columns: int): str

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຈະມີການແຊກຖັນວ່າງໄວ້ທາງຊ້າຍຂອງມັນ, ໃນຮູບແບບສະຕຣິງ.

wholecolumn: ຖ້າຕັ້ງເປັນ False (ຄ່າເລີ່ມຕົ້ນ), ຄວາມສູງຂອງຖັນທີ່ແຊກຈະເທົ່າກັບຄວາມສູງຂອງ range ທີ່ກຳນົດ. ຖ້າບໍ່ດັ່ງນັ້ນ, ຖັນທີ່ແຊກຈະກວມເອົາທຸກແຖວໃນແຜ່ນງານ.

columns: ຈຳນວນຖັນທີ່ຈະແຊກ. ຄ່າເລີ່ມຕົ້ນແມ່ນຄວາມກວ້າງຂອງ range ຕົ້ນສະບັບ.

ຕົວຢ່າງ:

ໃນ Basic

    ' ຍ້າຍຊ່ວງ "A3:A6" ໄປທາງຂວາໜຶ່ງຖັນ; ມີຜົນກະທົບສະເພາະແຖວ 3 ຫາ 6
    oDoc.ShiftRight("A3:A6")
    ' ຍ້າຍຊ່ວງ "A3:A6" ໄປທາງຂວາຫ້າຖັນ
    oDoc.ShiftRight("A3:A6", Columns := 5)
    ' ຖັນທີ່ແຊກເຂົ້າໄປແມ່ນກວມເອົາທຸກແຖວໃນແຜ່ນງານ
    oDoc.ShiftRight("A3:A6", WholeColumn := True)
  
ໃນ Python

    myDoc.ShiftRight("A3:A6")
    myDoc.ShiftRight("A3:A6", columns = 5)
    myDoc.ShiftRight("A3:A6", wholecolumn = True)
  

SortRange

ຈັດລຽງຊ່ວງທີ່ກຳນົດຕາມຈຳນວນຖັນ/ແຖວໃດກໍໄດ້. ລຳດັບການຈັດລຽງອາດຈະແຕກຕ່າງກັນໄປຕາມຖັນ/ແຖວ. ຖ້າຈຳນວນຄີໃນການຈັດລຽງ (sort keys) ຫຼາຍກວ່າ 3, ຊ່ວງຈະຖືກຈັດລຽງຫຼາຍຄັ້ງ ໂດຍແບ່ງເປັນກຸ່ມລະ 3 ຄີ ເລີ່ມຈາກຄີສຸດທ້າຍ. ມັນຈະສົ່ງຄືນສະຕຣິງທີ່ສະແດງເຖິງຊ່ວງເຊລທີ່ຖືກປ່ຽນແປງ. ຂະໜາດຂອງພື້ນທີ່ທີ່ຖືກປ່ຽນແປງແມ່ນຖືກກຳນົດໂດຍຂະໜາດຂອງພື້ນທີ່ຕົ້ນທາງທັງໝົດ.

ໄວຍາກອນ:

svc.SortRange(range: str, sortkeys: any, sortorder: any = "ASC", destinationcell: str = "", containsheader: bool = False, casesensitive: bool = False, sortcolumns: bool = False): str

ພາຣາມິເຕີ:

range: ຊ່ວງທີ່ຈະຈັດລຽງ, ໃນຮູບແບບສະຕຣິງ.

sortkeys: ຄ່າສະກາລາ (ຖ້າເປັນ 1 ຖັນ/ແຖວ) ຫຼື ອາເຣຂອງເລກຖັນ/ແຖວ ໂດຍເລີ່ມຈາກ 1.

sortorder: ຄ່າສະກາລາ ຫຼື ອາເຣຂອງສະຕຣິງທີ່ມີຄ່າ "ASC" (ນ້ອຍໄປຫາຫຼາຍ), "DESC" (ຫຼາຍໄປຫານ້ອຍ). ແຕ່ລະລາຍການຈະຖືກຈັບຄູ່ກັບລາຍການທີ່ກົງກັນໃນ sortkeys. ຖ້າອາເຣ sortorder ສັ້ນກວ່າ sortkeys, ຄີທີ່ເຫຼືອຈະຖືກຈັດລຽງແບບ "ASC".

destinationcell: ເຊລປາຍທາງຂອງຊ່ວງເຊລທີ່ຈັດລຽງແລ້ວ, ໃນຮູບແບບສະຕຣິງ. ຖ້າໃຫ້ມາເປັນຊ່ວງ, ຈະພິຈາລະນາພຽງແຕ່ເຊລເທິງຊ້າຍເທົ່ານັ້ນ. ໂດຍເລີ່ມຕົ້ນ ຊ່ວງຕົ້ນທາງຈະຖືກຂຽນທັບ.

containsheader: ເມື່ອເປັນ True, ແຖວ/ຖັນທຳອິດຈະບໍ່ຖືກຈັດລຽງ.

casesensitive: ສະເພາະການປຽບທຽບສະຕຣິງ. ຄ່າເລີ່ມຕົ້ນ = False

sortcolumns: ເມື່ອເປັນ True, ຖັນຈະຖືກຈັດລຽງຈາກຊ້າຍໄປຂວາ. ຄ່າເລີ່ມຕົ້ນ = False: ແຖວຈະຖືກຈັດລຽງຈາກເທິງລົງລຸ່ມ.

ຕົວຢ່າງ:

ໃນ Basic

    'ຈັດລຽງຊ່ວງຕາມຖັນ A (ນ້ອຍໄປຫຼາຍ) ແລະ C (ຫຼາຍໄປຫານ້ອຍ)
    oDoc.SortRange("A2:J200", Array(1, 3), Array("ASC", "DESC"), CaseSensitive := True)
  
ໃນ Python

    myDoc.SortRange("A2:J200", (1, 3), ("ASC", "DESC"), casesensitive = True)
  
ໄອຄອນ ຄຳເຕືອນ

ຣູທີນ ຫຼື ຕົວລະບຸ Basic ຂອງ ScriptForge ທັງໝົດທີ່ຂຶ້ນຕົ້ນດ້ວຍເຄື່ອງໝາຍຂີດກ້ອງ "_" ແມ່ນສະຫງວນໄວ້ສຳລັບໃຊ້ພາຍໃນ. ພວກມັນບໍ່ໄດ້ມີໄວ້ໃຫ້ໃຊ້ໃນມາໂຄຣ Basic ຫຼື ສະຄຣິບ Python.


ກະລຸນາສະໜັບສະໜູນພວກເຮົາ!

ກະລຸນາສະໜັບສະໜູນພວກເຮົາ!