Upload to server
uploading
This commit is contained in:
@@ -0,0 +1,195 @@
|
||||
/***************************************************************************
|
||||
|
||||
Copyright (c) Microsoft Corporation 2011.
|
||||
|
||||
This code is licensed using the Microsoft Public License (Ms-PL). The text of the license can be found here:
|
||||
|
||||
http://www.microsoft.com/resources/sharedsource/licensingbasics/publiclicense.mspx
|
||||
|
||||
***************************************************************************/
|
||||
|
||||
using System;
|
||||
using System.Management.Automation;
|
||||
|
||||
namespace OpenXmlPowerTools.Commands
|
||||
{
|
||||
/// <summary>
|
||||
/// Cmdlet for setting a value for a specific cell in a worksheet in a SpreadsheetML document
|
||||
/// </summary>
|
||||
[Cmdlet(VerbsCommon.Set, "OpenXmlSpreadSheetCellValue", SupportsShouldProcess = true)]
|
||||
[OutputType("OpenXmlPowerToolsDocument")]
|
||||
public class SetOpenXmlSpreadSheetCellValueCmdlet : PowerToolsModifierCmdlet
|
||||
{
|
||||
#region Parameters
|
||||
private int fromRow;
|
||||
private int toRow;
|
||||
private short fromColumn;
|
||||
private short toColumn;
|
||||
private string _value;
|
||||
private string worksheetName;
|
||||
|
||||
/// <summary>
|
||||
/// Initial row for start setting the value
|
||||
/// </summary>
|
||||
[Parameter(Position = 2,
|
||||
Mandatory = true,
|
||||
HelpMessage = "Initial row for start setting the value")]
|
||||
[ValidateNotNullOrEmpty]
|
||||
public int FromRow
|
||||
{
|
||||
get
|
||||
{
|
||||
return fromRow;
|
||||
}
|
||||
set
|
||||
{
|
||||
if(value >0)
|
||||
{
|
||||
fromRow = value;
|
||||
}
|
||||
else
|
||||
{
|
||||
new System.Management.Automation.ParameterBindingException("Initial row must be greater than zero");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Initial row for start setting the value
|
||||
/// </summary>
|
||||
[Parameter(Position = 3,
|
||||
Mandatory = true,
|
||||
HelpMessage = "Final row for start setting the value")]
|
||||
[ValidateNotNullOrEmpty]
|
||||
public int ToRow
|
||||
{
|
||||
get
|
||||
{
|
||||
return toRow;
|
||||
}
|
||||
set
|
||||
{
|
||||
if (value > 0)
|
||||
{
|
||||
toRow = value;
|
||||
}
|
||||
else
|
||||
{
|
||||
new System.Management.Automation.ParameterBindingException("Final row must be greater than zero");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Initial column for start setting the value
|
||||
/// </summary>
|
||||
[Parameter(Position = 4,
|
||||
Mandatory = true,
|
||||
HelpMessage = "Initial column for start setting the value")]
|
||||
[ValidateNotNullOrEmpty]
|
||||
public short FromColumn
|
||||
{
|
||||
get
|
||||
{
|
||||
return fromColumn;
|
||||
}
|
||||
set
|
||||
{
|
||||
if (value > 0)
|
||||
{
|
||||
fromColumn = value;
|
||||
}
|
||||
else
|
||||
{
|
||||
new System.Management.Automation.ParameterBindingException("Initial column must be greater than zero");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Final column for start setting the value
|
||||
/// </summary>
|
||||
[Parameter(Position = 5,
|
||||
Mandatory = true,
|
||||
HelpMessage = "Final column for start setting the value")]
|
||||
[ValidateNotNullOrEmpty]
|
||||
public short ToColumn
|
||||
{
|
||||
get
|
||||
{
|
||||
return toColumn;
|
||||
}
|
||||
set
|
||||
{
|
||||
if (value > 0)
|
||||
{
|
||||
toColumn = value;
|
||||
}
|
||||
else
|
||||
{
|
||||
new System.Management.Automation.ParameterBindingException("Final column must be greater than zero");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Cell value
|
||||
/// </summary>
|
||||
[Parameter(Position = 6,
|
||||
Mandatory = true,
|
||||
HelpMessage = "Cell value")]
|
||||
[ValidateNotNullOrEmpty]
|
||||
public string Value
|
||||
{
|
||||
get
|
||||
{
|
||||
return _value;
|
||||
}
|
||||
set
|
||||
{
|
||||
_value = value;
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Worksheet name to set the cell value
|
||||
/// </summary>
|
||||
[Parameter(Position = 7,
|
||||
Mandatory = true,
|
||||
HelpMessage = "Worksheet name to set the cell value")]
|
||||
[ValidateNotNullOrEmpty]
|
||||
public string WorksheetName
|
||||
{
|
||||
get
|
||||
{
|
||||
return worksheetName;
|
||||
}
|
||||
set
|
||||
{
|
||||
worksheetName = value;
|
||||
}
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Cmdlet Overrides
|
||||
|
||||
protected override void ProcessRecord()
|
||||
{
|
||||
foreach (var document in AllDocuments("Set-OpenXmlSpreadSheetCellValue"))
|
||||
{
|
||||
try
|
||||
{
|
||||
if (!(document is SmlDocument))
|
||||
throw new PowerToolsDocumentException("Not a spreadsheet document.");
|
||||
OutputDocument(WorksheetAccessor.SetCellValue((SmlDocument)document, worksheetName, fromRow, toRow, fromColumn, toColumn, _value));
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
WriteError(PowerToolsExceptionHandling.GetExceptionErrorRecord(e, document));
|
||||
}
|
||||
}
|
||||
}
|
||||
#endregion
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user