Posts

Donate

Attach Single Event To A Control Array At Run Time Using LINQ And C#

In a scenario wherein you need to attach a single event like CheckedChanged() to a control array such as CheckBox controls, the common way to do it is using for each or for loop. Another way to achieve it is using LINQ's ForEach() method as demonstrated below. Event Code 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 void CheckBoxGeneric_CheckedChanged ( object sender, EventArgs e) { var checkBox = (CheckBox)sender; if (checkBox.Name == "chkBurger" ) { //... } else if (checkBox.Name == "chkSoda" ) { //... } else { //... } } Attach the event to the control array 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 private CheckBox[] OrderItems; OrderItems = new CheckBox[] { chkBurger, chkSoda, chkIceCream }; private void Form1_Load ( object sender, EventArgs e) { //solution 1 using foreach loop //foreach (var checkControl in OrderItems) //{ // checkControl.CheckedChanged += new EventHandler(CheckBoxGeneric_CheckedChanged); ...

Using Microsoft.mshtml With The WebBrowser Control In C#

Image
Hello and Good Evening When working with a WebBrowser to extract information from a webpage, the most common classes that are probably used to traverse or navigate it's DOM are from the System.Windows.Forms namespace such as HtmlDocument, HtmlElementCollection and etc. Another way to navigate and traverse the DOM of the WebBrowser's HTMLDocument is using the Microsoft.mshtml namespace which contains interfaces for the rendering engine of Internet Explorer. So to access those interfaces and in your application, add reference to Microsoft.mshtml. In the code sample below, set alias for the Microsoft.mshtml namespace. You need to explicitly specify the namespace of a class or interface as MSHTML since Windows.Forms also have same class names with the former. And one thing to remember is that, empty results in mshtml does not yield nulls. Instead, it produces DBNull value. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 using MSHTML = mshtml; //set namespace alia...

IsDBNull() Equivalent in C#

When working with DBNull values in VB.NET you can check if that object is of type DBNull using IsDBNull(object) . So, to do this in C#, I have two options to do this. The first one is to get the type of that object and compare it with typeof(System.DBNull). Code 1 2 3 4 5 var attribute = element.getAttribute( "data-mixvids" ); if (attribute.GetType() != typeof (System.DBNull)) { lstElementVids.Add(element.getAttribute( "data-mixvids" )); } The other one is presented in MSDN docs using DBNull.Value.Equals(object) which returns true. Code 1 2 3 4 5 var attribute = element.getAttribute( "data-mixvids" ); if (!System.DBNull.Value.Equals(attribute)) { lstElementVids.Add(element.getAttribute( "data-mixvids" )); } Reference: MSDN Convert.IsDBNull Method (Object)

WebBrowser How To Fire Click Event Of Input Submit Element In C# And VB.NET

Given in a webpage there are several input elements and you want to fire the click event of an input element of type submit, here's how to do it using the Webbrowser control. C# 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 HtmlElementCollection htmlElementCollection = new HtmlElementCollection(); if (WebBrowser1.Document != null ) { htmlElementCollection = WebBrowser1.Document.GetElementsByTagName( "input" ); if (htmlElementCollection != null && htmlElementCollection.Count > 0) { foreach (HtmlElement element in htmlElementCollection) { if (element.GetAttribute( "value" ).Equals( "Submit" )) { element.InvokeMember( "click" ); } } } } VB.NET 1 2 3 4 5 6 7 8 9 10 11 12 13 Dim htmlElementCollection As HtmlElementCollection If (WebBrowser1.Document IsNot Nothing ) Then With WebBrowser1.Document htmlElem...

Regular Expression Extract Url From String Using Regex.Matches() In C#

Here's how to extract url(s) from a string or document using Regex.Matches() method. The Regex.Matches() method returns an array object MatchCollection in which you can access individual elements using it's index. Code: 1 2 3 4 5 6 7 8 9 10 11 12 string pattern = "(http|ftp|https):\\/\\/[\\w\\-_]+(\\.[\\w\\-_]+)+([\\w\\-\\.,@?^=%&amp;:/~\\+#]*[\\w\\-\\@?^=%&amp;/~\\+#])?" ; string Input = "<<abcdefghijklmnopqrstuvwxyz ABCDEFGHIJKLMNOPQRSTUVWXYZ\"abcd\" href=\"https://mediatemple.net\"" + "Sample text for testing>http://regexr.com/foo.html?q=bar>" ; string url1 = string .Empty; string url2 = string .Empty; if (Regex.Matches(Input, pattern).Count > 0) { MatchCollection matches = Regex.Matches(Input, pattern); url1 = matches[0].Value; url2 = matches[1].Value; }

Remove Cookies From CookieContainer Class

The CookieContainer class does not contain a method that clears or removes the cookies associated with it. To remove them, you have to set each cookie's Expired property to True as shown below. C# 1 2 3 4 var cookies = cookieContainer.GetCookies( new Uri( "http://your_url_example_here" )); foreach (Cookie co in cookies) { co.Expired = true ; } VB.NET 1 2 3 4 Dim cookies = cookieContainer.GetCookies( New Uri( "http://your_url_example_here" )) For Each co As Cookie In cookies co.Expired = True Next

Show All Folders Inside Directory Sorted By Creation Time Using Linq In C# And VB.NET

Here's a solution using LINQ that will retrieve all folders inside a specific directory in order of creation time. C# 1 2 3 4 5 6 7 8 9 10 11 12 string path = @"C:\" ; if (Directory.Exists(path)) { DirectoryInfo dir = new DirectoryInfo(path); DirectoryInfo[] directories = dir.GetDirectories(). OrderByDescending(p => p.CreationTime). ToArray(); if (directories.Length > 0) { foreach (DirectoryInfo directory in directories) { ListBox1.Items.Add(directory.Name); } } } VB.NET 1 2 3 4 5 6 7 8 9 10 11 12 Dim path As String = "C:\" If Directory.Exists(path) Then Dim dir As New DirectoryInfo(path) Dim directories As DirectoryInfo() = dir.GetDirectories(). OrderByDescending(Function(p) p.CreationTime). ToArray() ...

Show Or Get IP Address in ASP.NET MVC

Here's a simple tutorial on how to get a user's IP address using ASP.NET MVC and jQuery. The fetching of record is triggered when the textbox receives focus. HTML Code 1 <input id= "txtID" type= "text" /> JavaScript Code 1 2 3 4 5 6 7 8 $(document).ready( function () { $( '#txtID' ).focus( function () { $.getJSON( '@Url.Action("GetIPAddress","getipaddress")' , function (result) { $( "#txtID" ).val(result); }); }); }); C# Code 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 public JsonResult GetIPAddress() { System.Web.HttpContext context = System.Web.HttpContext.Current; string ipAddress = context.Request.ServerVariables[ "HTTP_X_FORWARDED_FOR" ]; string output = string .Empty; if (! string .IsNullOrEmpty(ipAddress)) { string [] addresses = ipAddress.Split( ',' )...

Operating System Error 5(Access is denied.) "Cannot open backup device" in SQL Server

Image
Here's how I manage to solve the issue Cannot open backup device with status Operating system error 5(Access is denied.) Steps 1. Right Click the Folder which is the backup destination 2. Click Properties -> Security Tab -> Click Advanced Button 3. On Permissions Tab -> choose Add -> Select Principal 4. In the "Enter the object name to select", type " NT Service\MSSQLSERVER ". -> OK     Note: NT Service\MSSQLSERVER is the Log On As value of     MSSQLSERVER service under Services. See screenshot below 5. In Multiple Names Found choose MSSQLSERVER. 6. Click OK 7. In Basic permissions panel, Choose Full Control 8. Click Apply -> OK -> OK to close Folder Properties dialog box SQL Server Service

How To Unpivot In SQL Server With Example

Image
Given the following records below, you may want to show them in a vertical manner instead of horizontal view of columns. To achieve the desired result, you use UNPIVOT clause in your query. 1 2 3 4 5 6 7 8 Use testdatabase Go SELECT [Subject], Grade FROM StudentReportCard UNPIVOT (Grade FOR [Subject] IN (English, Math, Literature, Biology)) AS U_SubjectGrade WHERE StudentId = 1 Screenshot

Donate