public static class ExcelHelper { #region 导入 /// <summary> /// 导入EXCEL(默认的sheet) /// </summary> /// <param name="fileName"></param> /// <returns></returns> public static System.Data.DataTable ImpExcelDt(string fileName) { return ImpExcelDt(fileName, "Sheet1"); } /// <summary> /// excel 导入 /// </summary> /// <param name="fileName"></param> /// <param name="sheetName"></param> /// <returns></returns> public static System.Data.DataTable ImpExcelDt(string fileName, string sheetName) { try { if (!File.Exists(fileName)) { return null; } string strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + fileName + ";Extended Properties='Excel 8.0;HDR=False;IMEX=1'"; OleDbConnection myConn = new OleDbConnection(strCon); string strCom = " SELECT * FROM [" + sheetName + "$] "; myConn.Open(); OleDbDataAdapter myCommand = new OleDbDataAdapter(strCom, myConn); DataSet myDataSet = new DataSet(); myCommand.Fill(myDataSet, "[" + sheetName + "$]"); myConn.Close(); System.Data.DataTable dt = myDataSet.Tables[0]; return dt; } catch(Exception ex) { throw ex; } } #endregion #region 导出到EXCEL /// <summary> /// 将数据导出到指定的Excel文件中 /// </summary> /// <param name="listView">System.Windows.Forms.ListView,指定要导出的数据源</param> /// <param name="destFileName">指定目标文件路径</param> /// <param name="tableName">要导出到的表名称</param> /// <param name="overWrite">指定是否覆盖已存在的表</param> /// <returns>导出的记录的行数</returns> public static int ExportToExcel(System.Data.DataTable dt, string destFileName, string tableName) { if (File.Exists(destFileName)) { File.Delete(destFileName); } //得到字段名 string szFields = ""; string szValues = ""; for (int i = 0; i < dt.Columns.Count; i++) { szFields += "[" + dt.Columns[i] + "],"; } szFields = szFields.TrimEnd(','); //定义数据连接 OleDbConnection connection = new OleDbConnection(); connection.ConnectionString = GetConnectionString(destFileName); OleDbCommand command = new OleDbCommand(); command.Connection = connection; command.CommandType = CommandType.Text; //打开数据库连接 try { connection.Open(); } catch { throw new Exception("目标文件路径错误。"); } //创建数据库表 try { command.CommandText = GetCreateTableSql("[" + tableName + "]", szFields.Split(',')); command.ExecuteNonQuery(); } catch (Exception ex) { //如果允许覆盖则删除已有数据 throw ex; } try { //循环处理数据------------------------------------------ int recordCount = 0; for (int i = 0; i < dt.Rows.Count; i++) { szValues = ""; for (int j = 0; j < dt.Columns.Count; j++) { szValues += "'" + dt.Rows[i][j] + "',"; } szValues = szValues.TrimEnd(','); //组合成SQL语句并执行 string szSql = "INSERT INTO [" + tableName + "](" + szFields + ") VALUES(" + szValues + ")"; command.CommandText = szSql; recordCount += command.ExecuteNonQuery(); } connection.Close(); return recordCount; } catch (Exception ex) { throw ex; } } //得到连接字符串 private static String GetConnectionString(string fullPath) { string szConnection; szConnection = "Provider=Microsoft.JET.OLEDB.4.0;Extended Properties=Excel 8.0;data source=" + fullPath; return szConnection; } //得到创建表的SQL语句 private static string GetCreateTableSql(string tableName, string[] fields) { string szSql = "CREATE TABLE " + tableName + "("; for (int i = 0; i < fields.Length; i++) { szSql += fields[i] + " VARCHAR(200),"; } szSql = szSql.TrimEnd(',') + ")"; return szSql; } #endregion }
以上就是C# EXCEL 导入导出类(OLEDB的方式)的示例代码详情的内容,更多相关内容请关注PHP中文网(www.php.cn)!

C#.netissusuitibleforenterprise-levelapplicationswithinthememicrosoftecosystemduetoitsstrongtyping, richlibraries, androbustperformance.

Proses pengaturcaraan C# dalam .NET termasuk langkah -langkah berikut: 1) Menulis C# Code, 2) Menyusun bahasa pertengahan (IL), dan 3) yang dilaksanakan oleh Runtime .NET (CLR). Kelebihan C# dalam .NET adalah sintaks moden, sistem jenis yang kuat dan integrasi yang ketat dengan Rangka Kerja .NET, sesuai untuk pelbagai senario pembangunan dari aplikasi desktop ke perkhidmatan web.

C# adalah bahasa pengaturcaraan yang berorientasikan objek moden yang dibangunkan oleh Microsoft dan sebagai sebahagian daripada Rangka Kerja .NET. 1.C# menyokong pengaturcaraan berorientasikan objek (OOP), termasuk enkapsulasi, warisan dan polimorfisme. 2. Pengaturcaraan Asynchronous dalam C# dilaksanakan melalui Async dan menunggu kata kunci untuk meningkatkan respons aplikasi. 3. Gunakan LINQ untuk memproses koleksi data dengan ringkas. 4. Kesilapan umum termasuk pengecualian rujukan null dan pengecualian indeks luar. Kemahiran penyahpepijatan termasuk menggunakan debugger dan pengendalian pengecualian. 5. Pengoptimuman Prestasi termasuk menggunakan StringBuilder dan mengelakkan pembungkusan yang tidak perlu dan unboxing.

Strategi ujian untuk aplikasi C#. NET termasuk ujian unit, ujian integrasi, dan ujian akhir-ke-akhir. 1. Ujian unit memastikan bahawa unit minimum kod berfungsi secara bebas, menggunakan rangka kerja MSTest, Nunit atau Xunit. 2. Ujian Bersepadu Mengesahkan fungsi pelbagai unit yang digabungkan, data simulasi yang biasa digunakan dan perkhidmatan luaran. 3. Ujian akhir-ke-akhir mensimulasikan proses operasi lengkap pengguna, dan selenium biasanya digunakan untuk ujian automatik.

Temu bual dengan pemaju kanan C# memerlukan menguasai pengetahuan teras seperti pengaturcaraan asynchronous, LINQ, dan prinsip kerja dalaman Rangka .NET. 1. Pengaturcaraan Asynchronous memudahkan operasi melalui async dan menunggu untuk meningkatkan respons aplikasi. 2.Linq mengendalikan data dalam gaya SQL dan perhatikan prestasi. 3. CLR kerangka bersih menguruskan ingatan, dan pengumpulan sampah perlu digunakan dengan berhati -hati.

C#.NET Soalan dan jawapan wawancara termasuk pengetahuan asas, konsep teras, dan penggunaan lanjutan. 1) Pengetahuan asas: C# adalah bahasa berorientasikan objek yang dibangunkan oleh Microsoft dan digunakan terutamanya dalam rangka .NET. 2) Konsep teras: Delegasi dan peristiwa membolehkan kaedah mengikat dinamik, dan LINQ menyediakan fungsi pertanyaan yang kuat. 3) Penggunaan Lanjutan: Pengaturcaraan Asynchronous meningkatkan respons, dan pokok ekspresi digunakan untuk pembinaan kod dinamik.

C#.NET adalah pilihan yang popular untuk membina microservices kerana ekosistem yang kuat dan sokongan yang kaya. 1) Buat RestfulAPi menggunakan ASP.Netcore untuk memproses penciptaan pesanan dan pertanyaan. 2) Gunakan GRPC untuk mencapai komunikasi yang cekap antara microservices, menentukan dan melaksanakan perkhidmatan pesanan. 3) Memudahkan penggunaan dan pengurusan melalui microservices kontena Docker.

Amalan terbaik keselamatan untuk C# dan .NET termasuk pengesahan input, pengekodan output, pengendalian pengecualian, serta pengesahan dan kebenaran. 1) Gunakan ungkapan biasa atau kaedah terbina dalam untuk mengesahkan input untuk mengelakkan data berniat jahat memasuki sistem. 2) Pengekodan output Untuk mencegah serangan XSS, gunakan kaedah httputility.htmlencode. 3) Pengendalian Pengecualian Menghindari kebocoran maklumat, ralat rekod tetapi tidak mengembalikan maklumat terperinci kepada pengguna. 4) Gunakan Asp.Netidentity dan kebenaran berasaskan tuntutan untuk melindungi aplikasi daripada akses yang tidak dibenarkan.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.