事故警示导入
This commit is contained in:
parent
9838c63107
commit
35c02437c4
Binary file not shown.
|
|
@ -0,0 +1,97 @@
|
||||||
|
{
|
||||||
|
"Version": 1,
|
||||||
|
"WorkspaceRootPath": "G:\\\u516C\u53F8\u9879\u76EE\\\u65B0\u7586\u6CB9\u5EFA\\",
|
||||||
|
"Documents": [],
|
||||||
|
"DocumentGroupContainers": [
|
||||||
|
{
|
||||||
|
"Orientation": 0,
|
||||||
|
"VerticalTabListWidth": 256,
|
||||||
|
"DocumentGroups": [
|
||||||
|
{
|
||||||
|
"DockedWidth": 321,
|
||||||
|
"SelectedChildIndex": -1,
|
||||||
|
"Children": [
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:0:0:{c6f34f0d-7ae5-4f3a-be61-fe0c21ae9eb8}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:134:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:133:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:130:0:{1fc202d4-d401-403c-9834-5b218574bb67}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:0:0:{eefa5220-e298-11d0-8f78-00a0c9110057}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:131:0:{1fc202d4-d401-403c-9834-5b218574bb67}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:141:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:142:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:143:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:144:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:145:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:140:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:137:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:139:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:138:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:128:0:{116d2292-e37d-41cd-a077-ebacac4c8cc4}"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"DockedWidth": 378,
|
||||||
|
"SelectedChildIndex": -1,
|
||||||
|
"Children": [
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:0:0:{d78612c7-9962-4b83-95d9-268046dad23a}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"$type": "Bookmark",
|
||||||
|
"Name": "ST:0:0:{34e76e81-ee4a-11d0-ae2e-00a0c90fffc3}"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
@ -3675,6 +3675,10 @@ namespace BLL
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public const string ExcelUrl = "File\\Excel\\Temp\\";
|
public const string ExcelUrl = "File\\Excel\\Temp\\";
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 事故警示导入模版文件原始的虚拟路径
|
||||||
|
/// </summary>
|
||||||
|
public const string AccidentWarningDataInUrl = "File\\Excel\\DataIn\\事故警示导入模板.xls";
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 岗位培训课程
|
/// 岗位培训课程
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
|
||||||
|
|
@ -34,8 +34,9 @@
|
||||||
<f:ToolbarFill ID="ToolbarFill1" runat="server">
|
<f:ToolbarFill ID="ToolbarFill1" runat="server">
|
||||||
</f:ToolbarFill>
|
</f:ToolbarFill>
|
||||||
<f:Button ID="btnSearch" runat="server" Text="查询" Icon="SystemSearch" OnClick="btnSearch_Click"></f:Button>
|
<f:Button ID="btnSearch" runat="server" Text="查询" Icon="SystemSearch" OnClick="btnSearch_Click"></f:Button>
|
||||||
<f:Button ID="btnNew" ToolTip="新增" Icon="Add" EnablePostBack="false" Hidden="true"
|
<f:Button ID="btnNew" ToolTip="新增" Text="新增" Icon="Add" EnablePostBack="false" Hidden="true" runat="server">
|
||||||
runat="server">
|
</f:Button>
|
||||||
|
<f:Button ID="btnImport" ToolTip="导入" Icon="PackageIn" runat="server" OnClick="btnImport_Click" Text="导入" Hidden="true">
|
||||||
</f:Button>
|
</f:Button>
|
||||||
<%--<f:Button ID="btnOut" OnClick="btnOut_Click" runat="server" ToolTip="导出" Icon="FolderUp"
|
<%--<f:Button ID="btnOut" OnClick="btnOut_Click" runat="server" ToolTip="导出" Icon="FolderUp"
|
||||||
EnableAjax="false" DisableControlBeforePostBack="false">
|
EnableAjax="false" DisableControlBeforePostBack="false">
|
||||||
|
|
@ -98,7 +99,10 @@
|
||||||
</Items>
|
</Items>
|
||||||
</f:Panel>
|
</f:Panel>
|
||||||
<f:Window ID="Window1" Title="事故事件" Hidden="true" EnableIFrame="true" EnableMaximize="true"
|
<f:Window ID="Window1" Title="事故事件" Hidden="true" EnableIFrame="true" EnableMaximize="true"
|
||||||
Target="Parent" EnableResize="false" runat="server" IsModal="true" Width="1024px" Height="700px">
|
Target="Parent" EnableResize="false" runat="server" IsModal="true" Width="1024px" Height="700px" OnClose="Window1_Close">
|
||||||
|
</f:Window>
|
||||||
|
<f:Window ID="Window2" Title="事故事件" Hidden="true" EnableIFrame="true" EnableMaximize="true"
|
||||||
|
Target="Parent" EnableResize="false" runat="server" IsModal="true" Width="1024px" Height="700px" OnClose="Window1_Close">
|
||||||
</f:Window>
|
</f:Window>
|
||||||
<f:Window ID="WindowAtt" Title="附件页面" Hidden="true" EnableIFrame="true" EnableMaximize="true"
|
<f:Window ID="WindowAtt" Title="附件页面" Hidden="true" EnableIFrame="true" EnableMaximize="true"
|
||||||
Target="Parent" EnableResize="false" runat="server" IsModal="true" Width="700px" Height="500px">
|
Target="Parent" EnableResize="false" runat="server" IsModal="true" Width="700px" Height="500px">
|
||||||
|
|
|
||||||
|
|
@ -143,6 +143,18 @@ namespace FineUIPro.Web.Accident
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region 关闭弹出窗口
|
||||||
|
/// <summary>
|
||||||
|
/// 关闭弹出窗口
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="sender"></param>
|
||||||
|
/// <param name="e"></param>
|
||||||
|
protected void Window1_Close(object sender, WindowCloseEventArgs e)
|
||||||
|
{
|
||||||
|
BindGrid();
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region 编辑
|
#region 编辑
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 双击事件
|
/// 双击事件
|
||||||
|
|
@ -223,6 +235,7 @@ namespace FineUIPro.Web.Accident
|
||||||
{
|
{
|
||||||
if (buttonList.Contains(BLL.Const.BtnAdd))
|
if (buttonList.Contains(BLL.Const.BtnAdd))
|
||||||
{
|
{
|
||||||
|
this.btnImport.Hidden = false;
|
||||||
this.btnNew.Hidden = false;
|
this.btnNew.Hidden = false;
|
||||||
}
|
}
|
||||||
if (buttonList.Contains(BLL.Const.BtnModify))
|
if (buttonList.Contains(BLL.Const.BtnModify))
|
||||||
|
|
@ -237,6 +250,19 @@ namespace FineUIPro.Web.Accident
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region 导入
|
||||||
|
/// <summary>
|
||||||
|
/// 导入按钮
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="sender"></param>
|
||||||
|
/// <param name="e"></param>
|
||||||
|
protected void btnImport_Click(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
PageContext.RegisterStartupScript(Window2.GetShowReference(String.Format("AccidentWarningDataIn.aspx", "导入 - ")));
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
|
||||||
#region 导出按钮
|
#region 导出按钮
|
||||||
/// 导出按钮
|
/// 导出按钮
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
|
||||||
|
|
@ -122,6 +122,15 @@ namespace FineUIPro.Web.Accident
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
protected global::FineUIPro.Button btnNew;
|
protected global::FineUIPro.Button btnNew;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// btnImport 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.Button btnImport;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// lblNumber 控件。
|
/// lblNumber 控件。
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
@ -167,6 +176,15 @@ namespace FineUIPro.Web.Accident
|
||||||
/// </remarks>
|
/// </remarks>
|
||||||
protected global::FineUIPro.Window Window1;
|
protected global::FineUIPro.Window Window1;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Window2 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.Window Window2;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// WindowAtt 控件。
|
/// WindowAtt 控件。
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,68 @@
|
||||||
|
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="AccidentWarningDataIn.aspx.cs" Inherits="FineUIPro.Web.Accident.AccidentWarningDataIn" %>
|
||||||
|
|
||||||
|
<!DOCTYPE html>
|
||||||
|
|
||||||
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
||||||
|
<head runat="server">
|
||||||
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
|
||||||
|
<title></title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<form id="form1" runat="server">
|
||||||
|
<f:PageManager ID="PageManager1" AutoSizePanelID="SimpleForm1" runat="server" OnCustomEvent="PageManager1_CustomEvent" />
|
||||||
|
<f:Form ID="SimpleForm1" ShowBorder="false" ShowHeader="false" AutoScroll="true"
|
||||||
|
BodyPadding="10px" runat="server" RedStarPosition="BeforeText" LabelAlign="Right">
|
||||||
|
<Toolbars>
|
||||||
|
<f:Toolbar ID="Toolbar2" Position="Top" ToolbarAlign="Right" runat="server">
|
||||||
|
<Items>
|
||||||
|
<f:HiddenField ID="hdFileName" runat="server">
|
||||||
|
</f:HiddenField>
|
||||||
|
<f:Button ID="btnAudit" Icon="ApplicationEdit" runat="server" ToolTip="审核" ValidateForms="SimpleForm1" Text="审核"
|
||||||
|
OnClick="btnAudit_Click">
|
||||||
|
</f:Button>
|
||||||
|
<f:Button ID="btnImport" Icon="ApplicationGet" runat="server" ToolTip="导入" ValidateForms="SimpleForm1" Text="导入"
|
||||||
|
OnClick="btnImport_Click">
|
||||||
|
</f:Button>
|
||||||
|
<f:Button ID="btnDownLoad" runat="server" Icon="ApplicationGo" ToolTip="下载模板" OnClick="btnDownLoad_Click" Text="下载模板">
|
||||||
|
</f:Button>
|
||||||
|
<f:HiddenField ID="hdCheckResult" runat="server">
|
||||||
|
</f:HiddenField>
|
||||||
|
</Items>
|
||||||
|
</f:Toolbar>
|
||||||
|
</Toolbars>
|
||||||
|
<Rows>
|
||||||
|
<f:FormRow>
|
||||||
|
<Items>
|
||||||
|
<f:FileUpload runat="server" ID="fuAttachUrl" EmptyText="选择要导入的文件" Label="选择要导入的文件"
|
||||||
|
LabelWidth="150px">
|
||||||
|
</f:FileUpload>
|
||||||
|
</Items>
|
||||||
|
</f:FormRow>
|
||||||
|
<f:FormRow>
|
||||||
|
<Items>
|
||||||
|
<f:Grid ID="gvErrorInfo" ShowBorder="true" EnableAjax="false" ShowHeader="false" Title="事故警示" EnableCollapse="true"
|
||||||
|
runat="server" BoxFlex="1" AllowCellEditing="true" ClicksToEdit="2" AllowSorting="true"
|
||||||
|
SortDirection="DESC" EnableColumnLines="true" ForceFit="true" AllowPaging="true" IsDatabasePaging="true" PageSize="10"
|
||||||
|
EnableRowDoubleClickEvent="true" AllowFilters="true" EnableTextSelection="True">
|
||||||
|
<Columns>
|
||||||
|
<f:TemplateField ColumnID="tfPageIndex" Width="55px" HeaderText="序号" HeaderTextAlign="Center" TextAlign="Center"
|
||||||
|
EnableLock="true" Locked="False">
|
||||||
|
<ItemTemplate>
|
||||||
|
<asp:Label ID="lblPageIndex" runat="server" Text='<%# gvErrorInfo.PageIndex * gvErrorInfo.PageSize + Container.DataItemIndex + 1 %>'></asp:Label>
|
||||||
|
</ItemTemplate>
|
||||||
|
</f:TemplateField>
|
||||||
|
<f:BoundField DataField="Row" HeaderText="错误行号">
|
||||||
|
</f:BoundField>
|
||||||
|
<f:BoundField DataField="Column" HeaderText="错误列">
|
||||||
|
</f:BoundField>
|
||||||
|
<f:BoundField DataField="Reason" HeaderText="错误类型">
|
||||||
|
</f:BoundField>
|
||||||
|
</Columns>
|
||||||
|
</f:Grid>
|
||||||
|
</Items>
|
||||||
|
</f:FormRow>
|
||||||
|
</Rows>
|
||||||
|
</f:Form>
|
||||||
|
</form>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
@ -0,0 +1,388 @@
|
||||||
|
using BLL;
|
||||||
|
using Model;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Data;
|
||||||
|
using System.Data.OleDb;
|
||||||
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
|
namespace FineUIPro.Web.Accident
|
||||||
|
{
|
||||||
|
public partial class AccidentWarningDataIn : PageBase
|
||||||
|
{
|
||||||
|
#region 定义变量
|
||||||
|
/// <summary>
|
||||||
|
/// 上传预设的虚拟路径
|
||||||
|
/// </summary>
|
||||||
|
private string initPath = Const.ExcelUrl;
|
||||||
|
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 错误集合
|
||||||
|
/// </summary>
|
||||||
|
public static List<Model.ErrorInfo> errorInfos = new List<Model.ErrorInfo>();
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region 加载
|
||||||
|
/// <summary>
|
||||||
|
/// 加载页面
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="sender"></param>
|
||||||
|
/// <param name="e"></param>
|
||||||
|
protected void Page_Load(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
if (!IsPostBack)
|
||||||
|
{
|
||||||
|
this.hdCheckResult.Text = string.Empty;
|
||||||
|
this.hdFileName.Text = string.Empty;
|
||||||
|
if (errorInfos != null)
|
||||||
|
{
|
||||||
|
errorInfos.Clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region 审核
|
||||||
|
/// <summary>
|
||||||
|
/// 审核
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="sender"></param>
|
||||||
|
/// <param name="e"></param>
|
||||||
|
protected void btnAudit_Click(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if (this.fuAttachUrl.HasFile == false)
|
||||||
|
{
|
||||||
|
ShowNotify("请您选择Excel文件!", MessageBoxIcon.Warning);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
string IsXls = Path.GetExtension(this.fuAttachUrl.FileName).ToString().Trim().ToLower();
|
||||||
|
if (IsXls != ".xls")
|
||||||
|
{
|
||||||
|
ShowNotify("只可以选择Excel文件!", MessageBoxIcon.Warning);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (errorInfos != null)
|
||||||
|
{
|
||||||
|
errorInfos.Clear();
|
||||||
|
}
|
||||||
|
string rootPath = Server.MapPath("~/");
|
||||||
|
string initFullPath = rootPath + initPath;
|
||||||
|
if (!Directory.Exists(initFullPath))
|
||||||
|
{
|
||||||
|
Directory.CreateDirectory(initFullPath);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.hdFileName.Text = BLL.Funs.GetNewFileName() + IsXls;
|
||||||
|
string filePath = initFullPath + this.hdFileName.Text;
|
||||||
|
this.fuAttachUrl.PostedFile.SaveAs(filePath);
|
||||||
|
ImportXlsToData(rootPath + initPath + this.hdFileName.Text);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
ShowNotify("'" + ex.Message + "'", MessageBoxIcon.Warning);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#region 读Excel提取数据
|
||||||
|
/// <summary>
|
||||||
|
/// 从Excel提取数据--》Dataset
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="filename">Excel文件路径名</param>
|
||||||
|
private void ImportXlsToData(string fileName)
|
||||||
|
{
|
||||||
|
//支持.xls和.xlsx,即包括office2010等版本的 HDR=Yes代表第一行是标题,不是数据;
|
||||||
|
string cmdText = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties=Excel 8.0;";
|
||||||
|
|
||||||
|
//建立连接
|
||||||
|
OleDbConnection conn = new OleDbConnection(string.Format(cmdText, fileName));
|
||||||
|
try
|
||||||
|
{
|
||||||
|
//打开连接
|
||||||
|
if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed)
|
||||||
|
{
|
||||||
|
conn.Open();
|
||||||
|
}
|
||||||
|
OleDbDataAdapter oleAdMaster = null;
|
||||||
|
DataTable m_tableName = new DataTable();
|
||||||
|
DataSet ds = new DataSet();
|
||||||
|
m_tableName = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
|
||||||
|
|
||||||
|
if (m_tableName != null && m_tableName.Rows.Count > 0)
|
||||||
|
{
|
||||||
|
|
||||||
|
m_tableName.TableName = m_tableName.Rows[0]["TABLE_NAME"].ToString().Trim();
|
||||||
|
|
||||||
|
}
|
||||||
|
string sqlMaster;
|
||||||
|
sqlMaster = " SELECT * FROM [" + m_tableName.TableName + "]";
|
||||||
|
oleAdMaster = new OleDbDataAdapter(sqlMaster, conn);
|
||||||
|
oleAdMaster.Fill(ds, "m_tableName");
|
||||||
|
oleAdMaster.Dispose();
|
||||||
|
conn.Close();
|
||||||
|
conn.Dispose();
|
||||||
|
|
||||||
|
AddDatasetToSQL(ds.Tables[0], 6);
|
||||||
|
hdCheckResult.Text = "1";
|
||||||
|
}
|
||||||
|
catch (Exception exc)
|
||||||
|
{
|
||||||
|
Response.Write(exc);
|
||||||
|
//return null;
|
||||||
|
// return dt;
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
conn.Close();
|
||||||
|
conn.Dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region 将Dataset的数据导入数据库
|
||||||
|
/// <summary>
|
||||||
|
/// 将Dataset的数据导入数据库
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="pds">数据集</param>
|
||||||
|
/// <param name="Cols">数据集行数</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
private bool AddDatasetToSQL(DataTable pds, int Cols)
|
||||||
|
{
|
||||||
|
string result = string.Empty;
|
||||||
|
int ic, ir;
|
||||||
|
ic = pds.Columns.Count;
|
||||||
|
if (ic < Cols)
|
||||||
|
{
|
||||||
|
ShowNotify("导入Excel格式错误!Excel只有" + ic.ToString().Trim() + "列", MessageBoxIcon.Warning);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
ir = pds.Rows.Count;
|
||||||
|
if (pds != null && ir > 0)
|
||||||
|
{
|
||||||
|
errorInfos.Clear();
|
||||||
|
var oldViewInfos = from x in Funs.DB.Accident_Warning
|
||||||
|
select x;
|
||||||
|
|
||||||
|
for (int i = 0; i < ir; i++)
|
||||||
|
{
|
||||||
|
string row0 = pds.Rows[i][0].ToString();
|
||||||
|
if (string.IsNullOrEmpty(row0))
|
||||||
|
{
|
||||||
|
errorInfos.Add(new ErrorInfo { Row = (i + 2).ToString(), Column = "事故标题", Reason = "此项为必填项!" });
|
||||||
|
}
|
||||||
|
string row1 = pds.Rows[i][1].ToString();
|
||||||
|
if (string.IsNullOrEmpty(row1))
|
||||||
|
{
|
||||||
|
errorInfos.Add(new ErrorInfo { Row = (i + 2).ToString(), Column = "事故地点", Reason = "此项为必填项!" });
|
||||||
|
}
|
||||||
|
string row2 = pds.Rows[i][2].ToString();
|
||||||
|
if (!string.IsNullOrEmpty(row2))
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
DateTime date = Convert.ToDateTime(row2.Trim());
|
||||||
|
}
|
||||||
|
catch (Exception)
|
||||||
|
{
|
||||||
|
errorInfos.Add(new ErrorInfo { Row = (i + 2).ToString(), Column = "事故日期", Reason = $"[{row2}]错误!" });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
errorInfos.Add(new ErrorInfo { Row = (i + 2).ToString(), Column = "事故日期", Reason = "此项为必填项!" });
|
||||||
|
}
|
||||||
|
if (!string.IsNullOrWhiteSpace(row0) && !string.IsNullOrWhiteSpace(row1) && !string.IsNullOrWhiteSpace(row2))
|
||||||
|
{
|
||||||
|
var acc = oldViewInfos.Where(x => x.Title == row0 && x.Address == row1 && x.AccidentDate == Convert.ToDateTime(row2.Trim()));
|
||||||
|
if (acc.Any())
|
||||||
|
{
|
||||||
|
errorInfos.Add(new ErrorInfo { Row = (i + 2).ToString(), Column = "事故标题", Reason = "此项事故已存在!" });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (errorInfos.Count > 0)
|
||||||
|
{
|
||||||
|
this.gvErrorInfo.DataSource = errorInfos;
|
||||||
|
this.gvErrorInfo.DataBind();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ShowNotify("审核完成,请点击导入!", MessageBoxIcon.Success);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ShowNotify("导入数据为空!", MessageBoxIcon.Warning);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region 导入
|
||||||
|
/// <summary>
|
||||||
|
/// 导入
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="sender"></param>
|
||||||
|
/// <param name="e"></param>
|
||||||
|
protected void btnImport_Click(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
if (!string.IsNullOrEmpty(hdCheckResult.Text))
|
||||||
|
{
|
||||||
|
if (errorInfos.Count <= 0)
|
||||||
|
{
|
||||||
|
string rootPath = Server.MapPath("~/");
|
||||||
|
ImportXlsToData2(rootPath + initPath + this.hdFileName.Text);
|
||||||
|
hdCheckResult.Text = string.Empty;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ShowNotify("请先将错误数据修正,再重新导入提交!", MessageBoxIcon.Warning);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ShowNotify("请先审核要导入的文件!", MessageBoxIcon.Warning);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#region Excel提取数据
|
||||||
|
/// <summary>
|
||||||
|
/// 从Excel提取数据--》Dataset
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="filename">Excel文件路径名</param>
|
||||||
|
private void ImportXlsToData2(string fileName)
|
||||||
|
{
|
||||||
|
//支持.xls和.xlsx,即包括office2010等版本的 HDR=Yes代表第一行是标题,不是数据;
|
||||||
|
string cmdText = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties=Excel 8.0;";
|
||||||
|
//建立连接
|
||||||
|
OleDbConnection conn = new OleDbConnection(string.Format(cmdText, fileName));
|
||||||
|
try
|
||||||
|
{
|
||||||
|
//打开连接
|
||||||
|
if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed)
|
||||||
|
{
|
||||||
|
conn.Open();
|
||||||
|
}
|
||||||
|
OleDbDataAdapter oleAdMaster = null;
|
||||||
|
DataTable m_tableName = new DataTable();
|
||||||
|
DataSet ds = new DataSet();
|
||||||
|
m_tableName = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
|
||||||
|
|
||||||
|
if (m_tableName != null && m_tableName.Rows.Count > 0)
|
||||||
|
{
|
||||||
|
|
||||||
|
m_tableName.TableName = m_tableName.Rows[0]["TABLE_NAME"].ToString().Trim();
|
||||||
|
|
||||||
|
}
|
||||||
|
string sqlMaster;
|
||||||
|
sqlMaster = " SELECT * FROM [" + m_tableName.TableName + "]";
|
||||||
|
oleAdMaster = new OleDbDataAdapter(sqlMaster, conn);
|
||||||
|
oleAdMaster.Fill(ds, "m_tableName");
|
||||||
|
oleAdMaster.Dispose();
|
||||||
|
conn.Close();
|
||||||
|
conn.Dispose();
|
||||||
|
|
||||||
|
AddDatasetToSQL2(ds.Tables[0], 6);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
throw ex;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
#region 将Dataset的数据导入数据库
|
||||||
|
/// <summary>
|
||||||
|
/// 将Dataset的数据导入数据库
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="pds">数据集</param>
|
||||||
|
/// <param name="Cols">数据集列数</param>
|
||||||
|
/// <returns></returns>
|
||||||
|
private bool AddDatasetToSQL2(DataTable pds, int Cols)
|
||||||
|
{
|
||||||
|
int ic, ir;
|
||||||
|
ic = pds.Columns.Count;
|
||||||
|
if (ic < Cols)
|
||||||
|
{
|
||||||
|
ShowNotify("导入Excel格式错误!Excel只有" + ic.ToString().Trim() + "列", MessageBoxIcon.Warning);
|
||||||
|
}
|
||||||
|
string result = string.Empty;
|
||||||
|
ir = pds.Rows.Count;
|
||||||
|
if (pds != null && ir > 0)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < ir; i++)
|
||||||
|
{
|
||||||
|
Model.Accident_Warning model = new Model.Accident_Warning();
|
||||||
|
model.Id = SQLHelper.GetNewID(typeof(Model.Accident_Warning));
|
||||||
|
model.Code = BLL.SQLHelper.RunProcNewId("SpGetNewCode5", "Accident_Warning", "Code", $"SG-");
|
||||||
|
model.Title = pds.Rows[i][0].ToString().Trim();
|
||||||
|
model.Address = pds.Rows[i][1].ToString().Trim();
|
||||||
|
DateTime accDate = Convert.ToDateTime(pds.Rows[i][2].ToString().Trim());
|
||||||
|
model.AccidentDate = accDate;
|
||||||
|
model.AccidentMonthDay = accDate.ToString("MM-dd");
|
||||||
|
model.ResponsibleUnit = pds.Rows[i][3].ToString().Trim();
|
||||||
|
model.Content = pds.Rows[i][4].ToString().Trim();
|
||||||
|
model.Remarks = pds.Rows[i][5].ToString().Trim();
|
||||||
|
model.CompileMan = this.CurrUser.UserId;
|
||||||
|
model.CompileManName = this.CurrUser.UserName;
|
||||||
|
model.CreateTime = DateTime.Now;
|
||||||
|
BLL.AccidentWarningService.AddAccidentWarning(model);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ShowNotify("导入数据为空!", MessageBoxIcon.Warning);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
ShowNotify("导入完成!", MessageBoxIcon.Success);
|
||||||
|
PageContext.RegisterStartupScript(ActiveWindow.GetHidePostBackReference());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
|
||||||
|
#region 下载模板
|
||||||
|
/// <summary>
|
||||||
|
/// 下载模板按钮
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="sender"></param>
|
||||||
|
/// <param name="e"></param>
|
||||||
|
protected void btnDownLoad_Click(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
PageContext.RegisterStartupScript(Confirm.GetShowReference("确定下载导入模板吗?", String.Empty, MessageBoxIcon.Question, PageManager1.GetCustomEventReference(false, "Confirm_OK"), PageManager1.GetCustomEventReference("Confirm_Cancel")));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 下载导入模板
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="sender"></param>
|
||||||
|
/// <param name="e"></param>
|
||||||
|
protected void PageManager1_CustomEvent(object sender, CustomEventArgs e)
|
||||||
|
{
|
||||||
|
if (e.EventArgument == "Confirm_OK")
|
||||||
|
{
|
||||||
|
string rootPath = Server.MapPath("~/");
|
||||||
|
string uploadfilepath = rootPath + Const.AccidentWarningDataInUrl;
|
||||||
|
string filePath = Const.AccidentWarningDataInUrl;
|
||||||
|
string fileName = Path.GetFileName(filePath);
|
||||||
|
FileInfo info = new FileInfo(uploadfilepath);
|
||||||
|
long fileSize = info.Length;
|
||||||
|
Response.ClearContent();
|
||||||
|
Response.AddHeader("Content-Disposition", "attachment;filename=" + System.Web.HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8));
|
||||||
|
Response.ContentType = "excel/plain";
|
||||||
|
Response.ContentEncoding = System.Text.Encoding.UTF8;
|
||||||
|
Response.AddHeader("Content-Length", fileSize.ToString().Trim());
|
||||||
|
Response.TransmitFile(uploadfilepath, 0, fileSize);
|
||||||
|
Response.End();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endregion
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,125 @@
|
||||||
|
//------------------------------------------------------------------------------
|
||||||
|
// <自动生成>
|
||||||
|
// 此代码由工具生成。
|
||||||
|
//
|
||||||
|
// 对此文件的更改可能导致不正确的行为,如果
|
||||||
|
// 重新生成代码,则所做更改将丢失。
|
||||||
|
// </自动生成>
|
||||||
|
//------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
namespace FineUIPro.Web.Accident
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
public partial class AccidentWarningDataIn
|
||||||
|
{
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// form1 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::System.Web.UI.HtmlControls.HtmlForm form1;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// PageManager1 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.PageManager PageManager1;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// SimpleForm1 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.Form SimpleForm1;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Toolbar2 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.Toolbar Toolbar2;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// hdFileName 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.HiddenField hdFileName;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// btnAudit 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.Button btnAudit;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// btnImport 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.Button btnImport;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// btnDownLoad 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.Button btnDownLoad;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// hdCheckResult 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.HiddenField hdCheckResult;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// fuAttachUrl 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.FileUpload fuAttachUrl;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// gvErrorInfo 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::FineUIPro.Grid gvErrorInfo;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// lblPageIndex 控件。
|
||||||
|
/// </summary>
|
||||||
|
/// <remarks>
|
||||||
|
/// 自动生成的字段。
|
||||||
|
/// 若要进行修改,请将字段声明从设计器文件移到代码隐藏文件。
|
||||||
|
/// </remarks>
|
||||||
|
protected global::System.Web.UI.WebControls.Label lblPageIndex;
|
||||||
|
}
|
||||||
|
}
|
||||||
Binary file not shown.
|
|
@ -171,6 +171,7 @@
|
||||||
</Reference>
|
</Reference>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<Content Include="Accident\AccidentWarningDataIn.aspx" />
|
||||||
<Content Include="Accident\AccidentWarning.aspx" />
|
<Content Include="Accident\AccidentWarning.aspx" />
|
||||||
<Content Include="Accident\AccidentWarningEdit.aspx" />
|
<Content Include="Accident\AccidentWarningEdit.aspx" />
|
||||||
<Content Include="AttachFile\dist\add-on\jplayer.playlist.js" />
|
<Content Include="AttachFile\dist\add-on\jplayer.playlist.js" />
|
||||||
|
|
@ -7630,6 +7631,13 @@
|
||||||
</Content>
|
</Content>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<Compile Include="Accident\AccidentWarningDataIn.aspx.cs">
|
||||||
|
<DependentUpon>AccidentWarningDataIn.aspx</DependentUpon>
|
||||||
|
<SubType>ASPXCodeBehind</SubType>
|
||||||
|
</Compile>
|
||||||
|
<Compile Include="Accident\AccidentWarningDataIn.aspx.designer.cs">
|
||||||
|
<DependentUpon>AccidentWarningDataIn.aspx</DependentUpon>
|
||||||
|
</Compile>
|
||||||
<Compile Include="Accident\AccidentWarning.aspx.cs">
|
<Compile Include="Accident\AccidentWarning.aspx.cs">
|
||||||
<DependentUpon>AccidentWarning.aspx</DependentUpon>
|
<DependentUpon>AccidentWarning.aspx</DependentUpon>
|
||||||
<SubType>ASPXCodeBehind</SubType>
|
<SubType>ASPXCodeBehind</SubType>
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue