Thursday 9 March 2017

Add Webpart programmatically

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.SharePoint;
//using Microsoft.SharePoint.WebControls;
using Microsoft.SharePoint.WebPartPages;
//using System.Web;
using System.Xml;
using IQS_CommentsView;

namespace IQS_AddwebpartProgramatically
{
    class Program
    {

        static void Main(string[] args)
        {
            int counter = 0;
            Console.WriteLine("Enter the Name of the site");
            Console.WriteLine("Enter the Zone");
            string ZoneId = Console.ReadLine();
            string ListName = "DW Individ List";
            string subsite = ""; string url = ""; int intLargestZoneIndex = 0;
            Program obj = new Program();
            using (SPSite site = new SPSite(""))
            {
                SPWeb web = site.OpenWeb();
                SPList spList = web.Lists[ListName];
                            SPListItemCollection items = spList.Items;

                            foreach (SPListItem item in items)
                            {
                                try
                                {
                                    int itmcnt = items.Count;
                                    if (counter < 3)//Set the counter
                                    {
                                        subsite = Convert.ToString(item["Link"]);
                                        string id = Convert.ToString(item["DW Individ No"]);
                                        string[] subsiteurl = subsite.Split(',');
                                        url = subsiteurl[0];


                                        web.AllowUnsafeUpdates = true;
                                        SPLimitedWebPartManager webParts = web.GetLimitedWebPartManager(url + "/default.aspx", System.Web.UI.WebControls.WebParts.PersonalizationScope.Shared); //Get webpart Manager
                                        //Create an instance of Custom Webpart and add in a Webpart zone
                                        IQS_CommentsView.IQS_CommentsViewWebPart wp = new IQS_CommentsViewWebPart();
                                        wp.Title = "My WebPart Using Object Model"; //Give Title
                                        intLargestZoneIndex = obj.getLargestZoneIndex(webParts);//Get largest zoneIndex, This is to add webpart to the last of webpart zone
                                        webParts.AddWebPart(wp, ZoneId, intLargestZoneIndex + 1);//If webpart should be added in the begining give third parameter 0(Zone index)
                                        webParts.SaveChanges(wp);
                                        web.Update();
                                    }
                                }
                                catch { }
                counter++; Console.WriteLine(counter);
                }
                web.Dispose();
                site.Dispose();
            }

        }
        public int getLargestZoneIndex(SPLimitedWebPartManager wpm)
        {
            int largestIndex = 0; int newIndex = 0;
            foreach (var webPartOnPage in wpm.WebParts)//GEt webparts in the page
            {
                try
                {
                    System.Web.UI.WebControls.WebParts.WebPart webPartObj =
                          (System.Web.UI.WebControls.WebParts.WebPart)(webPartOnPage);
                   
                    newIndex = webPartObj.ZoneIndex;
                    if (largestIndex < newIndex)//Find the largest of ZoneIndex
                    {
                        largestIndex = newIndex;
                    }
                }
                catch { }
            }
            return largestIndex;

        }
    }
}

Programmatically Update Quick Launch Sharepoint 2007

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.SharePoint;
using Microsoft.SharePoint.Navigation;

namespace UpdateQL
{
    class Program
    {
        static void Main(string[] args)
        {
             
            int i = 0;
            string ListName = "";
            //string ListName = "ess";
            Int32 intStartItmID = 32;
            Int32 intEndItmID = 32;


            SPSecurity.RunWithElevatedPrivileges(delegate()
            {
                using (SPSite site = new SPSite(""))
                {
                    SPWeb web = site.OpenWeb();
                    SPList spList = web.Lists[ListName];
                    SPQuery spQItems = new SPQuery();
                    spQItems.Query = "<Where>   <And>  <Geq>  <FieldRef Name='ID' /><Value Type='Counter'>" + intStartItmID + "</Value> " +
                                   "  </Geq>         <Leq><FieldRef Name='ID' />     <Value Type='Counter'>" + intEndItmID + "</Value>   " +
                                   "  </Leq>               </And>       </Where>";
                    SPListItemCollection items = spList.GetItems(spQItems);
                    if (items.Count > 0)
                    {
                        i = items.Count;
                        foreach (SPListItem item in items)
                        {

                            if (item["Vessel_x0020_Control_x0020_Link"] != null)
                            {
                                SPFieldUrlValue spfuv = new SPFieldUrlValue(item["Vessel_x0020_Control_x0020_Link"].ToString());
                                using (SPSite subSite = new SPSite(spfuv.Url))
                                {
                                    using (SPWeb subWeb = subSite.OpenWeb())
                                    {
                                        SPNavigationNodeCollection nodeColl = subWeb.Navigation.QuickLaunch;
                                        int count = nodeColl.Count;
                                        foreach (SPNavigationNode heading in nodeColl)
                                        {
                                           
                                            foreach (SPNavigationNode links in heading.Children)
                                            {
                                                int iHeadCount = heading.Children.Count;  
                                                if (links.Title == "Resources internal")
                                                {
                                                    links.Delete();
                                                    break;
                                                }
                                            }
                                        }
                                    }
                                }

                            }

                            i = i - 1;
                        }
                    }

                }
            });
        }
       
    }
    public class URL
    {
        public static void UpdateURL(SPNavigationNode cNode, string from, string to)
        {


            if (cNode.Url.IndexOf(from) > 0)
            {
                Console.WriteLine("FOUND CULPRIT -> " + cNode.Title.ToString() +
             " :: " + cNode.Url.ToString());
                cNode.Url = cNode.Url.ToString().Replace(from, to);
                cNode.Update();
                Console.WriteLine(cNode.Title.ToString() + " :: " + cNode.Url.ToString());
            }

        }
    }
}

Delete a Webpart in sharepoint 2007

 public static void RemoveWebPart()
//        {
//            using (SPSite spSite = new SPSite(""))
//            {
//                using (SPWeb spWeb = spSite.OpenWeb())
//                {
//                    SPList lstdocking = spWeb.Lists["Projects - general"];
//                    SPQuery spQrydocking = new SPQuery();
//                    spQrydocking.Query = @"<Where>
//      <And>
//         <Eq>
//            <FieldRef Name='Project_x0020_type_x002e_' />
//            <Value Type='Text'>Dry docking</Value>
//         </Eq>
//         <IsNotNull>
//            <FieldRef Name='Link' />
//         </IsNotNull>
//      </And>
//   </Where>";
//                    SPListItemCollection itemColl = lstdocking.GetItems(spQrydocking);
//                    foreach (SPListItem item in itemColl)
//                    {
//                        SPFieldUrlValue value = new SPFieldUrlValue(Convert.ToString(item["Link"]));
//                        string URL = value.Url;
//                        if (URL != "" && URL != null)
//                        {
//                            using (SPSite site = new SPSite(URL))
//                            {
//                                using (SPWeb web = site.OpenWeb())
//                                {
//                                    web.AllowUnsafeUpdates = true;
//                                    Microsoft.SharePoint.WebPartPages.SPLimitedWebPartManager mgr = null;
//                                    mgr = web.GetLimitedWebPartManager("default.aspx", System.Web.UI.WebControls.WebParts.PersonalizationScope.Shared);
//                                    SPLimitedWebPartCollection wpc = mgr.WebParts;
//                                    try
//                                    {
//                                        foreach (System.Web.UI.WebControls.WebParts.WebPart webPart in wpc)
//                                        {

//                                            {
//                                                if (webPart.Title == "IQS_DocumentViewer")
//                                                {
//                                                    using (webPart)
//                                                    {
//                                                        // mgr.DeleteWebPart(webPart);
//                                                        Console.WriteLine("Webpart Deleted : " + web.Name);
//                                                    }
//                                                }
//                                            }
//                                        }
//                                    }
//                                    catch { }
//                                }
//                            }
//                        }
//                    }
//                }
//            }



//        }

Set Permission to a list and web in sharepoint 2007

  public static void Setpermission(SPWeb subWeb, SPListItem lstItm)
        {
            bool status= true;
           
            SPRoleAssignmentCollection spRoleAssignmentCol = lstItm.RoleAssignments;
            foreach (SPRoleAssignment sprol in spRoleAssignmentCol)
            {
                if (sprol.Member.Name == "Directors")
                {
                    status = false;
                }
            }
            if (status)
            {
                if (!lstItm.ParentList.HasUniqueRoleAssignments)
                {
                    lstItm.ParentList.BreakRoleInheritance(true);
                }
                SPGroup sgroup = lstItm.Web.Groups["Directors"];
                // set unique permissions for listitem. Current user will automatically get full control
                lstItm.BreakRoleInheritance(false);
                SPRoleAssignment spRoleAssignment = new SPRoleAssignment(sgroup);
                //SPRoleDefinition spRoleDefinition = elevatedWeb.RoleDefinitions[LocalizationStrings.NewProject.NewProjectStrings.ContributePermission];
                SPRoleDefinition spRoleDefinition = lstItm.Web.RoleDefinitions["Contribute"];
                if (!spRoleAssignment.RoleDefinitionBindings.Contains(spRoleDefinition))
                    spRoleAssignment.RoleDefinitionBindings.Add(spRoleDefinition);

                lstItm.RoleAssignments.Add(spRoleAssignment);
                subWeb.RoleAssignments.Add(spRoleAssignment);
                subWeb.Update();
            }
        }

Delete a Field From a list Programmatically sharepoint 2007

 using (SPSite site = new SPSite(strSiteUrl))
            {
                using (SPWeb web = site.OpenWeb())
                {
                    SPList spls = web.Lists[strList];
                    string[] strArrFields = strFields.Split(',');
                    foreach (string strfield in strArrFields)
                    {


                        foreach (SPField spfield in spls.Fields)
                        {
                            if (spfield.Title == strfield && spfield.InternalName == "Department_x0020_Manager")
                            {
                                spfield.Delete();
                                break;
                            }
                        }
                    }
                }
            }

Set field as optional in Sharepoint 2007

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.SharePoint;

namespace ConsoleApplication_SetFieldOptional
{
    class Program
    {
        static void Main(string[] args)
        {
           
            //string strLinkField = "Site,Link,Link";
            //string[] strArrlist=strListName.Split(',');
            // string[] strArrLinkField=strLinkField.Split(',');
            // SPUser userAdm = tempCurrentWeb.AllUsers[@"\site-admin"];
            // SPUserToken tokenPO = userAdm.UserToken;
             using (SPSite site = new SPSite(strSiteUrl))
            {
                using(SPWeb web= site.OpenWeb())
                {
                    foreach (SPWeb web1 in web.Webs)
                    {
                        // SPList spls = web.Lists[strListName];
                        //foreach (SPListItem item in spls.Items)
                        {
                            // string strLink=item[spls.Fields[strArrLinkField[i]].InternalName]!= null ?item[spls.Fields[strArrLinkField[i]].InternalName].ToString().Split(',')[0]:"";
                            // if (strLink != "")
                            {
                                using (SPSite Subsite = new SPSite(web1.Url))
                                {
                                    using (SPWeb newSubWeb = openWebPermissions(Subsite.OpenWeb()))
                                    {
                                        SPUser userAdm = newSubWeb.AllUsers[@"iqubes\iqs-site-admin"];
                                        SPUserToken tokenPO = userAdm.UserToken;
                                        #region code to make the "Resource" field of "Resources" list hidden
                                        try
                                        {
                                           
                                            HideField(newSubWeb, tokenPO, "Resources", "Resource");
                                        }
                                        catch
                                        {
                                            ;
                                        }
                                        #endregion
                                        #region code to make the "Contact name" field of "Contacts" list optional
                                        try
                                        {
                                            //SPUser userAdm = tempCurrentWeb.AllUsers[Utility.AdminAccount];
                                            //SPUserToken tokenPO = userAdm.UserToken;
                                            SetFieldOptional(newSubWeb, tokenPO, "Contacts", "Contact name");
                                        }
                                        catch
                                        {
                                            ;
                                        }
                                        #endregion
                                        #region code to make the "Title" field of "Documents" list optional
                                        try
                                        {
                                            //SPUser userAdm = tempCurrentWeb.AllUsers[Utility.AdminAccount];
                                            //SPUserToken tokenPO = userAdm.UserToken;
                                            SetFieldOptional(newSubWeb, tokenPO, "Documents", "Title");

                                        }
                                        catch
                                        {
                                            ;
                                        }
                                        #endregion
                                    }
                                }
                            }
                        }
                     
                    }
                }
            }
        }

        public static void SetFieldOptional(SPWeb newSubWeb, SPUserToken tokenPO, string Listname, string Fieldname)
        {
            try
            {

                //SPSecurity.RunWithElevatedPrivileges(delegate()
                //{
                //    using (SPSite site = new SPSite(newSubWeb.Url, tokenPO))
                //    {
                //        using (SPWeb web = site.OpenWeb())
                //        {
                newSubWeb.AllowUnsafeUpdates = true;
                SPList SubList = newSubWeb.Lists[Listname];
                SPContentType SubContentType = SubList.ContentTypes[0];
                SPField spSubField = SubContentType.Fields.GetField(Fieldname);
                SPFieldLinkCollection linksFlds = SubContentType.FieldLinks;
                var Curlink = linksFlds[spSubField.Id];
                if (Curlink != null && Curlink.Required == true)
                {
                    Curlink.Required = false;
                    SubContentType.Update(false);
                }
                newSubWeb.AllowUnsafeUpdates = false;
                //        }
                //    }
                //});
            }
            catch
            {
            }
        }
        public static void HideField(SPWeb newSubWeb, SPUserToken tokenPO, string Listname, string Fieldname)
        {
            try
            {

                //SPSecurity.RunWithElevatedPrivileges(delegate()
                //{
                //    using (SPSite site = new SPSite(newSubWeb.Url, tokenPO))
                //    {
                //        using (SPWeb web = site.OpenWeb())
                //        {
                            newSubWeb.AllowUnsafeUpdates = true;
                            SPList SubList = newSubWeb.Lists[Listname];
                            SPContentType SubContentType = SubList.ContentTypes[0];
                            SPField spSubField = SubContentType.Fields.GetField(Fieldname);
                            SPFieldLinkCollection linksFlds = SubContentType.FieldLinks;
                            var Curlink = linksFlds[spSubField.Id];
                            if (Curlink != null && Curlink.Required == true)
                            {
                                Curlink.Hidden = true;
                                SubContentType.Update(false);
                            }
                            newSubWeb.AllowUnsafeUpdates = false;
                //        }
                //    }
                //});
            }
            catch
            {
            }
        }
        private const string _adminUser = "-site-admin";
        private static SPWeb openWebPermissions(SPWeb currentWeb)
        {
            try
            {
                SPUser user = currentWeb.AllUsers[_adminUser];
                SPUserToken token = user.UserToken;
                SPSite site = new SPSite(currentWeb.Url, token);
                SPWeb web = site.OpenWeb();
                web.AllowUnsafeUpdates = true;

                return web;
            }
            catch (Exception ex)
            {

            }
            return currentWeb;
        }
    }
}

Get User And Group Console

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.SharePoint;
using System.IO;

namespace ConsoleApplication_GetUserandGroup
{
    class Program
    {
        static void Main(string[] args)
        {
         
            using (SPSite site = new SPSite(strSite))
            {
                using (SPWeb web = site.OpenWeb())
                {
                    try
                    {
                        SPUserCollection alluser = web.AllUsers;
                        foreach (SPUser user in alluser)
                        {
                            string strUserandGroup = "";
                            foreach (SPGroup grp in user.Groups)
                            {
                                strUserandGroup = strUserandGroup != "" ? strUserandGroup + "," + grp.Name : grp.Name;
                            }
                            strUserandGroup = user.Name + ":" + strUserandGroup;
                            StreamWriter OurStream;
                            if (!File.Exists(@"C:\CCS\~IQS-Svn-Code\Console Apps\ConsoleApplication_GetUserandGroup\UserandGroup.txt"))
                                OurStream = File.CreateText(@"C:\CCS\~IQS-Svn-Code\Console Apps\ConsoleApplication_GetUserandGroup\UserandGroup.txt");
                            else
                                OurStream = File.AppendText(@"C:\CCS\~IQS-Svn-Code\Console Apps\ConsoleApplication_GetUserandGroup\UserandGroup.txt");
                            // OurStream.WriteLine("---------------------------------------------------------");
                            OurStream.WriteLine(strUserandGroup);
                            OurStream.Close();
                        }
                    }
                    catch { }
                    try
                    {
                        SPGroupCollection allgroups = web.Groups;
                        foreach (SPGroup grp in allgroups)                      
                        {
                            StreamWriter OurStream1;
                            string strGroupUser = "";
                            foreach (SPUser user in grp.Users)
                            {
                                strGroupUser = strGroupUser != "" ? strGroupUser + "," + user.Name : user.Name;
                            }
                            strGroupUser = grp.Name + ":" + strGroupUser;

                            if (!File.Exists(@"C:\CCS\~IQS-Svn-Code\Console Apps\ConsoleApplication_GetUserandGroup\GroupandUsers.txt"))
                                OurStream1 = File.CreateText(@"C:\CCS\~IQS-Svn-Code\Console Apps\ConsoleApplication_GetUserandGroup\GroupandUsers.txt");
                            else
                                OurStream1 = File.AppendText(@"C:\CCS\~IQS-Svn-Code\Console Apps\ConsoleApplication_GetUserandGroup\GroupandUsers.txt");
                            // OurStream.WriteLine("---------------------------------------------------------");
                            OurStream1.WriteLine(strGroupUser);
                            OurStream1.Close();
                        }
                    }
                    catch { }



                }
            }
        }
    }
}

Read From Excel and update in a list

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.SharePoint;
using System.Data;

using System.IO;
using System.Xml;
using System.Net;
using Excel;
using System.Data.SqlClient;
//using Excel = Microsoft.Office.Interop.Excel;
namespace Solstad_ReadFromExcelUpdateCharteringContarct
{
    class Program
    {
        static void Main(string[] args)
        {
            AddIntoDB();
            return;
            FileStream stream = File.Open("C:\\CCS\\Console Applications\\Solstad\\HSE_PPIR.xlsx", FileMode.Open, FileAccess.Read);
                    DataSet result = null;
                        System.Data.DataTable dtResult = null;
                        //Reading Excel file from document library.

                        IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream);
                        excelReader.IsFirstRowAsColumnNames = true;

                        //Converting it into Dataset.
                        result = excelReader.AsDataSet();
                        dtResult = result.Tables[0];
                        //  saasWeb.AllowUnsafeUpdates = true;
                        for (int i = 0; i < dtResult.Rows.Count; i++)
                        {
                            //Parent List
                            //string parentList= "Chartering Contract";
                            string parentList = "";
                            //string childList = "Vessel Chartering Contract";
                            string childList = "";
                           
                            SPSecurity.RunWithElevatedPrivileges(delegate()
                            {
                                using (SPSite site = new SPSite(""))
                                {
                                    SPWeb web = site.OpenWeb();
                                    SPList spList = web.Lists[parentList];
                                    SPQuery spQItems = new SPQuery();
                                    spQItems.Query = "<Where><Eq><FieldRef Name='Kontrakts_x0020_ID' /><Value Type='Text'>"+Convert.ToString(dtResult.Rows[i]["Contract ID"])+"</Value></Eq></Where>";
                                    SPListItemCollection items = spList.GetItems(spQItems);
                                    if (items.Count > 0)
                                    {
                                        foreach (SPListItem item in items)
                                        {
                                            item["ApplyStaircaserates"] = false;
                                            using (DisabledItemEventsScope scope = new DisabledItemEventsScope())
                                            {
                                                item.SystemUpdate(false);
                                            }

                                            SPList lstChildList = web.Lists["Vessel Chartering Contract"];
                                            SPQuery spqChild = new SPQuery();
                                            spqChild.Query = "<Where><Eq><FieldRef Name='Contract_x0020_ID' /><Value Type='Text'>" + Convert.ToString(item["ID"]) + "</Value></Eq></Where>";
                                            SPListItemCollection childItemsColn = lstChildList.GetItems(spqChild);
                                            if (childItemsColn.Count > 0)
                                            {
                                                foreach (SPListItem childItem in childItemsColn)
                                                {
                                                    childItem["ApplyStaircaserates"] = false;
                                                    using (DisabledItemEventsScope scope = new DisabledItemEventsScope())
                                                    {
                                                        childItem.SystemUpdate(false);
                                                        Console.WriteLine("ID:" + Convert.ToString(item["ID"]));
                                                    }
                                                }
                                            }
                                        }
                                    }
                                }
                            });
         
         
                        }

        }
        public static void AddIntoDB()
        {
            FileStream stream = File.Open("C:\\CCS\\Console Applications\\Solstad\\HSE_PPIR.xlsx", FileMode.Open, FileAccess.Read);
            DataSet result = null;
            System.Data.DataTable dtResult = null;
            //Reading Excel file from document library.

            IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream);
            excelReader.IsFirstRowAsColumnNames = true;

            //Converting it into Dataset.
            result = excelReader.AsDataSet();
            dtResult = result.Tables[0];
            if (dtResult.Rows.Count > 0)
            {
                for (int i = 0; i < dtResult.Rows.Count; i++)
                {
                    string strVessel = Convert.ToString(dtResult.Rows[i]["Column1"]);
                    string strPPIR = Convert.ToString(dtResult.Rows[i]["Column11"]);
                    if (strVessel.Trim() != "")
                    {

                    }
                }
            }
        }
     
   
    }
    class DisabledItemEventsScope : SPItemEventReceiver, IDisposable
    {
        public DisabledItemEventsScope()
        {
            base.DisableEventFiring();
        }

        #region IDisposable Members

        public void Dispose()
        {
            base.EnableEventFiring();
        }

        #endregion
    }
}

Webpart property Updates via a console

using System;
using System.Collections.Generic;

using System.Collections;
using System.Configuration;
using System.Data;

using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;

using System.Reflection;
using Microsoft.SharePoint;
using Microsoft.SharePoint.WebPartPages;

namespace WebpartPropertyConsole
{
    class Program
    {
       
        static void Main(string[] args)
        {
            try
            {
             
                SPSite tempSite = new SPSite("");
                SPWeb tempSPWeb = tempSite.OpenWeb();

                //chartering contract list
               
                //SPList _PGList = tempSPWeb.Lists["Companies"];
                int iTotalItems = _PGList.ItemCount;
                int count = 1;


                int intStartIndex = 106;
                int intEndIndex = 696;

                for (int i = intStartIndex; i <= intEndIndex; i++)
                {
                    //if (i != 2416)
                    {
                        try
                        {
                            SPSecurity.RunWithElevatedPrivileges(delegate()
                            {
                                try
                                {
                                    SPListItem spli = _PGList.GetItemById(i);
                                    if (spli["Link"] != null)
                                    {
                                        SPFieldUrlValue spfuv = new SPFieldUrlValue(spli["Link"].ToString());
                                        //AddWebpartProperty(spfuv.Url, "Sub Projects", "MainListFilterField", "Link to main project", spli["ID"].ToString(), _PGList.ID.ToString());
                                        //AddWebpartProperty(spfuv.Url, "Sub Projects", "PortfolioField", "Main project", spli["ID"].ToString(), _PGList.ID.ToString());
                                        //AddWebpartProperty(spfuv.Url, "Ongoing Valve Delivery Process", "SourceFields", "IQS unique ID,Project name,Link,Project Type,Department,End user", spli["ID"].ToString(), _PGList.ID.ToString());
                                        //AddWebpartProperty(spfuv.Url, "All Valve Delivery Process", "SourceFields", "IQS unique ID,Project name,Link,Project Type,Department,End user", spli["ID"].ToString(), _PGList.ID.ToString());
                                        //AddWebpartProperty(spfuv.Url, "Assign Serial Number for Parts", "ParentListSerialNoField", "Serial No", spli["ID"].ToString(), _PGList.ID.ToString());
                                        //AddWebpartProperty(spfuv.Url, "Assign Serial Number for Parts", "EquOrPartNo", "Part no", spli["ID"].ToString(), _PGList.ID.ToString());
                                        //AddWebpartProperty(spfuv.Url, "Assign Serial Number for Parts", "SerialNo", "Part Serial no", spli["ID"].ToString(), _PGList.ID.ToString());
                                        //AddWebpartProperty(spfuv.Url, "Assign Serial Number for Tools", "PartInventory", "Equipment inventory", spli["ID"].ToString(), _PGList.ID.ToString());
                                        //AddWebpartProperty(spfuv.Url, "Assign Serial Number for Tools", "PartInventoryFieldPartNo", "Equipment no", spli["ID"].ToString(), _PGList.ID.ToString());
                                        AddWebpartProperty(spfuv.Url, "Chartering Contract | Details", "LinkStyle", "font-family:verdana;color:#002B54;padding-top:16px;padding-left:16px;font-size:15px;font-weight:bold;", spli["ID"].ToString(), _PGList.ID.ToString());
                                        //AddWebpartProperty(spfuv.Url, "Assign Serial Number for Parts", "StatusFieldValue", "", spli["ID"].ToString(), _PGList.ID.ToString());

                                        //AddWebpartProperty(spfuv.Url, "Assign Serial Number for Tools", "Hidenewserialno", "NO", spli["ID"].ToString(), _PGList.ID.ToString());
                                        //AddWebpartProperty(spfuv.Url, "Assign Serial Number for Tools", "Equipmentserialnoguidformat", "NO", spli["ID"].ToString(), _PGList.ID.ToString());
                                        Console.WriteLine(count + "/" + iTotalItems);
                                        count++;

                                    }
                                    else
                                    {

                                    }
                                }
                                catch
                                {



                                }
                            });
                        }

                        catch
                        {
                            ;
                        }
                    }

                }

            }
            catch
            {
                ;
            }

        }
     

        #region Add Property
        /// <summary>
        ///
        /// </summary>
        /// <param name="weburl"></param>
        /// <param name="webPartName"></param>
        /// <param name="webpartProprty"> property that is set in webpart code (note: not display name)</param>
        /// <param name="webpartPropertyValue"></param>
        /// <param name="id"></param>
        /// <param name="strlist"></param>
        /// <param name="spWeb1Parent"></param>

        public static void AddWebpartProperty(string weburl, string webPartName, string webpartProprty, string webpartPropertyValue, string id, string strlist)
        {

            //string strTargetSite = "http://ccsentshivm058/shibu/default.aspx";
            string strTargetSite = weburl;
            SPSite spsSite = new SPSite(strTargetSite);
            SPWeb spwWeb = spsSite.OpenWeb();

            string stringrelativeurl = spwWeb.ServerRelativeUrl;
            spwWeb.AllowUnsafeUpdates = true;

            //const string KEY_CHK = "DWIndivid_weburl";

            //if (!spwWeb.Properties.ContainsKey(KEY_CHK))
            //{
            //    spwWeb.Properties.Add("DWIndivid_weburl", spWeb1Parent.Url);  // create web url
            //}
            //else
            //{
            //    spwWeb.Properties.Remove("DWIndivid_weburl");  // create web url
            //    spwWeb.Properties.Add("DWIndivid_weburl", spWeb1Parent.Url);
            //}

            //if (!spwWeb.Properties.ContainsKey("DWIndivid_RelativeWebUrl"))
            //{
            //    spwWeb.Properties.Add("DWIndivid_RelativeWebUrl", spWeb1Parent.ServerRelativeUrl); //relatiev url

            //}
            //else
            //{
            //    spwWeb.Properties.Remove("DWIndivid_RelativeWebUrl");
            //    spwWeb.Properties.Add("DWIndivid_RelativeWebUrl", spWeb1Parent.ServerRelativeUrl);
            //}
            //if (!spwWeb.Properties.ContainsKey("DWIndivid_ListID"))
            //{
            //    spwWeb.Properties.Add("DWIndivid_ListID", strlist); //relatiev url
            //}
            //else
            //{
            //    spwWeb.Properties.Remove("DWIndivid_ListID");
            //    spwWeb.Properties.Add("DWIndivid_ListID", strlist);
            //}
            //if (!spwWeb.Properties.ContainsKey("DWIndivid_ItemID"))
            //{
            //    spwWeb.Properties.Add("DWIndivid_ItemID", id); //relatiev url
            //}
            //else
            //{
            //    spwWeb.Properties.Remove("DWIndivid_ItemID");
            //    spwWeb.Properties.Add("DWIndivid_ItemID", id);
            //}

            //spwWeb.Properties.Update();//save site property


            // checking webpart property is having ',' at the end
            //checking webpart propertyvalue is having ','at the end

            string str = webpartProprty.Substring(webpartProprty.Length - 1);
            if (str == ",")
            {


            }
            else
            {
                webpartProprty = webpartProprty + ",";
            }
            string strpro = webpartPropertyValue.Substring(webpartPropertyValue.Length );
            if (strpro == ",")
            {

            }
            else
            {
                webpartPropertyValue = webpartPropertyValue + ",";
            }

            //Delivery%20Ticket%20Report.aspx
            //SPWebPartCollection wpcWebParts = spwWeb.GetWebPartCollection("default.aspx", Storage.Shared);

            //SPWebPartCollection wpcWebParts = spwWeb.GetWebPartCollection("/webpartpages/bussprocess.aspx", Storage.Shared);
            //WorkOrderOutReport.aspx
            //    string strRelativeUrl = spwWeb.ServerRelativeUrl.ToString() + "/" + "webpartpages/bussprocess.aspx";
            //string strRelativeUrl = spwWeb.ServerRelativeUrl.ToString() + "/WebPage/OngoingProjects.aspx"; //+ "/" + "webpartpages/Quotation And Invoice Webpart.aspx";
            // string strRelativeUrl = spwWeb.ServerRelativeUrl.ToString() + "/default.aspx"; //+ "/" + "webpartpages/Quotation And Invoice Webpart.aspx";
            //string strRelativeUrl = spwWeb.ServerRelativeUrl.ToString() + "/webpartpages/Serial No Allocation WebPart For Part.aspx"; //+ "/" + "webpartpages/Quotation And Invoice Webpart.aspx";
            string strRelativeUrl = spwWeb.ServerRelativeUrl.ToString() + "/default.aspx"; //+ "/" + "webpartpages/Quotation And Invoice Webpart.aspx";

            //Serial%20No%20AllocationWebPart.aspx
            // string strRelativeUrl = spwWeb.ServerRelativeUrl.ToString() + "/" + "webpartpages/busprocess.aspx";
            SPWebPartCollection wpcWebParts = spwWeb.GetWebPartCollection(strRelativeUrl, Storage.Shared);

            //http://nos.signin.no/DivAB-12-004587/webpartpages/Delivery%20Ticket%20Report.aspx

            foreach (Microsoft.SharePoint.WebPartPages.WebPart wptWebPart in wpcWebParts) //going through each webpart
            {
                //Console.WriteLine(wptWebPart.Title.ToString());
                //if (wptWebPart.Title == webPartName.ToString()) //comparing webpart name with title
                string str3 = wptWebPart.Title;
                if (wptWebPart.Title == webPartName)
                {
                    PropertyInfo[] pinProperties = wptWebPart.GetType().GetProperties(BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.Instance);
                    foreach (PropertyInfo pinProperty in pinProperties)
                    {
                        string[] prpname = webpartProprty.Split(','); //Taking webpart property name;
                        string[] val = webpartPropertyValue.Split(',');//Taking webpart property value
                        string strwebpartPropertyValue = webpartPropertyValue.ToString();
                        strwebpartPropertyValue = strwebpartPropertyValue.Remove(strwebpartPropertyValue.Length - 1);

                        int i = 0;

                        foreach (string word in prpname)
                        {
                            //Console.WriteLine(strwebpartPropertyValue.ToString());
                            if (pinProperty.Name == word)
                            {
                                // Console.WriteLine(pinProperty.Name.ToString());

                                //pinProperties.SetValue(wptWebPart,

                                // bool bValue = true;                              
                                //   pinProperty.SetValue(wptWebPart, bValue, null); // setting true or false


                                //pinProperty.SetValue(wptWebPart, val[i], null); //setting  webpart  value
                               
                                pinProperty.SetValue(wptWebPart, strwebpartPropertyValue, null);
                                wpcWebParts.SaveChanges(wptWebPart.StorageKey);//saving changes

                            }
                            i++;
                        }


                    }
                    //if (webPartName == "Ongoing Valve Delivery Process")
                    //{
                    //    wptWebPart.Title = "Ongoing Business Process";
                    //}
                    //if (webPartName == "All Valve Delivery Process")
                    //{
                    //    wptWebPart.Title = "All Business Process";
                    //}
                    //wpcWebParts.SaveChanges(wptWebPart.StorageKey);

                    break;
                }
            }


            spwWeb.AllowUnsafeUpdates = false;
            spwWeb.Dispose();
            spsSite.Dispose();
            //Console.ReadLine();

        }


        #endregion
    }
}

Hide Webpart and Remove it from Quick Launch

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.SharePoint;
using Microsoft.SharePoint.WebControls;
using Microsoft.SharePoint.WebPartPages;
using System.Web;
using System.Xml;
using System.Web.UI;
using Microsoft.SharePoint.Navigation;
namespace Solstad_HIdeWebpartandQuickLaunch
{
    class Program
    {
        static void Main(string[] args)
        {
            int i = 0;
            string ListName = "ListNAme";

            Int32 intStartItmID = 106;
            Int32 intEndItmID = 648;
            SPSecurity.RunWithElevatedPrivileges(delegate()
            {
                using (SPSite site = new SPSite("SiteName"))
                {

                    SPWeb web = site.OpenWeb();
                    SPList spList = web.Lists[ListName];
                    SPQuery spQItems = new SPQuery();
                    spQItems.Query = "<Where>   <And>  <Geq>  <FieldRef Name='ID' /><Value Type='Counter'>" + intStartItmID + "</Value> " +
                                   "  </Geq>         <Leq><FieldRef Name='ID' />     <Value Type='Counter'>" + intEndItmID + "</Value>   " +
                                   "  </Leq>               </And>       </Where>";
                    SPListItemCollection items = spList.GetItems(spQItems);
                    if (items.Count > 0)
                    {
                        i = items.Count;
                        foreach (SPListItem item in items)
                        {
                            //string strPropjectType = Convert.ToString(item["Project_x0020_type_x002e_"]);
                            //if (strPropjectType == "General Project")
                            //{
                            string strLink = Convert.ToString(item["Link"]);
                         
                                if (strLink != "")
                                {
                                    try
                                    {
                                        SPFieldUrlValue spfuv = new SPFieldUrlValue(strLink.ToString());

                                        SPSite SubSite = new SPSite(spfuv.Url);
                                        SPWeb subWeb = SubSite.OpenWeb();

                                        /*
                                        Microsoft.SharePoint.WebPartPages.SPLimitedWebPartManager mgr = null;
                                        mgr = subWeb.GetLimitedWebPartManager("default.aspx", System.Web.UI.WebControls.WebParts.PersonalizationScope.Shared);

                                        foreach (System.Web.UI.WebControls.WebParts.WebPart myWebPart in mgr.WebParts)
                                        {
                                            if (myWebPart.Title == "IQS_BusinessProcess_ProcessesViewer")
                                            {
                                                myWebPart.Hidden = false;
                                                mgr.SaveChanges(myWebPart);
                                                break;
                                            }
                                            //Business Process

                                        }
                                         */
                                     
                                        int j;
                                        SPNavigationNodeCollection quickLaunchNodes = subWeb.Navigation.QuickLaunch;
                                        foreach (SPNavigationNode node in quickLaunchNodes)
                                        {
                                            //for (int k = 0; k < quickLaunchNodes[0].Children.Count; k++)
                                            //{
                                            SPNavigationNode nn;
                                            try
                                            {
                                                nn = quickLaunchNodes.Navigation.GetNodeById(quickLaunchNodes[0].Children[0].Id);
                                                if (nn.Title.Equals("Contract Life Cycle Process"))
                                                {
                                                    nn.Delete();
                                                }
                                               
                                            }
                                            catch { }
                                            try
                                            {
                                                nn = quickLaunchNodes.Navigation.GetNodeById(quickLaunchNodes[0].Children[1].Id);
                                                if (nn.Title.Equals("Contract Life Cycle Process"))
                                                {
                                                    nn.Delete();
                                                }
                                            }
                                            catch { }
                                            //nn = nodesDemo.Navigation.GetNodeById(nodesDemo[i].Children[j].Id);
                                            //if (node.Title.Equals("QCP Process"))
                                            //{;
                                            //    node.Delete();
                                            //}
                                            //}
                                        }
                                        i = i - 1;
                                       
                                        Console.WriteLine("ID" + Convert.ToString(item["ID"]));
                                        //Console.ReadLine();
                                        //for (j = subWeb.Navigation.QuickLaunch.Count - 1; j > 0; j--)
                                        //{

                                        //    //subWeb.Navigation.QuickLaunch.Delete(subWeb.Navigation.QuickLaunch[i]);
                                        //}
                                    }
                                    catch { }
                                }
                           
                            //}
                           
                        }
                    }
               

                }
            });
        }
     
    }
}