Ответ 1
EPPlus может по умолчанию блокировать все блокируемые ячейки, и в этом случае вам нужно установить атрибут Locked
в false
для других столбцов, а затем установить IsProtected на true
.
Есть ли способ сделать столбец или группу ячеек заблокированными или прочитанными только с помощью EPPlus? Я пробовал код ниже как отдельно, так и вместе, но, похоже, не имеет желаемого эффекта. Либо весь лист заблокирован (если я включаю оператор IsProtected
) или вообще ничего.
ws.Protection.IsProtected = true;
ws.Column(10).Style.Locked = true;
ИЗМЕНИТЬ
Вот полный блок кода из моего контроллера
FileInfo newFile = new FileInfo("C:\\Users\\" + User.Identity.Name + "\\Desktop" + @"\\ZipCodes.xlsx");
ExcelPackage pck = new ExcelPackage(newFile);
var ws = pck.Workbook.Worksheets.Add("Query_" + DateTime.Now.ToString());
//Headers
ws.Cells["A1"].Value = "ChannelCode";
ws.Cells["B1"].Value = "DrmTerrDesc";
ws.Cells["C1"].Value = "IndDistrnId";
ws.Cells["D1"].Value = "StateCode";
ws.Cells["E1"].Value = "ZipCode";
ws.Cells["F1"].Value = "EndDate";
ws.Cells["G1"].Value = "EffectiveDate";
ws.Cells["H1"].Value = "LastUpdateId";
ws.Cells["J1"].Value = "ErrorCodes";
ws.Cells["K1"].Value = "Status";
ws.Cells["I1"].Value = "Id";
//Content
int i = 2;
foreach (var zip in results)
{
ws.Cells["A" + i.ToString()].Value = zip.ChannelCode;
ws.Cells["B" + i.ToString()].Value = zip.DrmTerrDesc;
ws.Cells["C" + i.ToString()].Value = zip.IndDistrnId;
ws.Cells["D" + i.ToString()].Value = zip.StateCode;
ws.Cells["E" + i.ToString()].Value = zip.ZipCode;
ws.Cells["F" + i.ToString()].Value = zip.EndDate.ToShortDateString();
ws.Cells["G" + i.ToString()].Value = zip.EffectiveDate.ToShortDateString();
ws.Cells["H" + i.ToString()].Value = zip.LastUpdateId;
ws.Cells["J" + i.ToString()].Value = zip.ErrorCodes;
ws.Cells["K" + i.ToString()].Value = zip.Status;
ws.Cells["I" + i.ToString()].Value = zip.Id;
i++;
}
//ws.Protection.IsProtected = true;
ws.Column(10).Style.Locked = true;
return new ExcelResult
{
FileName = "ZipCodes.xlsx",
Package = pck
};
ExcelResult
public class ExcelResult : ActionResult
{
public string FileName { get; set; }
public ExcelPackage Package { get; set; }
public override void ExecuteResult(ControllerContext context)
{
context.HttpContext.Response.Buffer = true;
context.HttpContext.Response.Clear();
context.HttpContext.Response.AddHeader("content-disposition", "attachment; filename=" + FileName);
context.HttpContext.Response.ContentType = "application/vnd.ms-excel";
context.HttpContext.Response.BinaryWrite(Package.GetAsByteArray());
}
}
Второе редактирование
Я попытался сделать рабочий лист защищенным, установив значение IsProtected
в true
, затем установите для свойства Locked
значение false
для каждого столбца, кроме последнего. Не только электронная таблица не была доступна только для чтения, но я мог редактировать данные в каждом столбце.
Я заметил, однако, что я не могу изменить размер самих столбцов, так что, возможно, это то, что я делаю. Однако я хотел бы заблокировать каждую ячейку в столбце, поэтому новые данные не могут быть введены.
for (int a = 1; a < 10; a++)
{
ws.Column(a).Style.Locked = false;
}
ws.Protection.IsProtected = true;
EPPlus может по умолчанию блокировать все блокируемые ячейки, и в этом случае вам нужно установить атрибут Locked
в false
для других столбцов, а затем установить IsProtected на true
.
Я добавляю два WorkSheets и должен защищать все столбцы, кроме одного по третьему индексу.
Это сработало для меня:)
worksheet2.Cells["A1"].LoadFromDataTable(dt_Data, true); //------load data from datatable
worksheet2.Protection.IsProtected = true; //--------Protect whole sheet
worksheet2.Column(3).Style.Locked = false; //-------Unlock 3rd column
Просто подумал, что я опубликую решение, если оно поможет кому-то еще. Я должен был установить всю рабочую таблицу для защиты, но установить для атрибута Locked
значение false для каждого поля не Id
.
//Content
int i = 2;
foreach (var zip in results)
{
//Set cell values
ws.Cells["A" + i.ToString()].Value = zip.ChannelCode;
ws.Cells["B" + i.ToString()].Value = zip.DrmTerrDesc;
ws.Cells["C" + i.ToString()].Value = zip.IndDistrnId;
ws.Cells["D" + i.ToString()].Value = zip.StateCode;
ws.Cells["E" + i.ToString()].Value = zip.ZipCode;
ws.Cells["F" + i.ToString()].Value = zip.EndDate.ToShortDateString();
ws.Cells["G" + i.ToString()].Value = zip.EffectiveDate.ToShortDateString();
ws.Cells["H" + i.ToString()].Value = zip.LastUpdateId;
ws.Cells["I" + i.ToString()].Value = zip.ErrorCodes;
ws.Cells["J" + i.ToString()].Value = zip.Status;
ws.Cells["K" + i.ToString()].Value = zip.Id;
//Unlock non-Id fields
ws.Cells["A" + i.ToString()].Style.Locked = false;
ws.Cells["B" + i.ToString()].Style.Locked = false;
ws.Cells["C" + i.ToString()].Style.Locked = false;
ws.Cells["D" + i.ToString()].Style.Locked = false;
ws.Cells["E" + i.ToString()].Style.Locked = false;
ws.Cells["F" + i.ToString()].Style.Locked = false;
ws.Cells["G" + i.ToString()].Style.Locked = false;
ws.Cells["H" + i.ToString()].Style.Locked = false;
ws.Cells["I" + i.ToString()].Style.Locked = false;
ws.Cells["J" + i.ToString()].Style.Locked = false;
i++;
}
//Since we have to make the whole sheet protected and unlock each cell
//to allow for editing this loop is necessary
for (int a = 65000 - i; i < 65000; i++)
{
//Unlock non-Id fields
ws.Cells["A" + i.ToString()].Style.Locked = false;
ws.Cells["B" + i.ToString()].Style.Locked = false;
ws.Cells["C" + i.ToString()].Style.Locked = false;
ws.Cells["D" + i.ToString()].Style.Locked = false;
ws.Cells["E" + i.ToString()].Style.Locked = false;
ws.Cells["F" + i.ToString()].Style.Locked = false;
ws.Cells["G" + i.ToString()].Style.Locked = false;
ws.Cells["H" + i.ToString()].Style.Locked = false;
ws.Cells["I" + i.ToString()].Style.Locked = false;
ws.Cells["J" + i.ToString()].Style.Locked = false;
}
//Set worksheet protection attributes
ws.Protection.AllowInsertRows = true;
ws.Protection.AllowSort = true;
ws.Protection.AllowSelectUnlockedCells = true;
ws.Protection.AllowAutoFilter = true;
ws.Protection.AllowInsertRows = true;
ws.Protection.IsProtected = true;
ws.Column(10).Style.Locked = true;
должен это сделать. пожалуйста, проверьте остальную часть кода на наличие ошибок:)
Итак, я рассматривал этот вопрос, и именно так я делаю блокировку.
worksheet.Protection.IsProtected = true;
//I'm creating a template for users to fill in data.These headers
//will come from database tables later on.
//So tableHeaders is an array of strings
for (int i = 1; i <= tableHeaders.Length; i++)
{
worksheet.Column(i).Style.Locked = false;
}
//And then lock the first row.
worksheet.Row(1).Style.Locked = true;
//Additionally don't allow user to change sheet names
excelPackage.Workbook.Protection.LockStructure = true;
сначала заблокируйте весь лист, а затем откройте ячейки, которые хотите разблокировать.
workSheet.Protection.IsProtected = true;
workSheet.Cells[2, 3, pocDeatils.CityMaster.Rows.Count + 1, 4].Style.Locked = false;
подробнее см. ссылку ниже: https://epplus.codeplex.com/SourceControl/latest#SampleApp/Sample6.cs