Ответы пользователя по тегу C#
  • Как в Visual Studio проверять грамматические ошибки при написании русскоязычных слов?

    andrewpianykh
    @andrewpianykh
    Используйте расширение Visual Studio Spell Checker
    Поддерживаются словари OpenOffice https://github.com/EWSoftware/VSSpellChecker/wiki/...
    Ответ написан
    Комментировать
  • DataGrid номер строки?

    andrewpianykh
    @andrewpianykh
    Вы можете получить строку по номеру используя индексатор:

    var rowIndex = 2;  // индекс первой строки равен 0
    var row = (SomeType)DataGrid.Items[rowIndex];
    row.SomeProperty = "...";
    Ответ написан
    Комментировать
  • Передать несколько переменных в Parallel.ForEach?

    andrewpianykh
    @andrewpianykh
    /*А нельзя ли просто объединить эти параметры в одну сущность, например так:
    class Prox
    {
        public string[] Prox1 {get;set;}
        public int[] Prox2 {get;set;}
    }*/


    Если количество строк в массивах равно, попробуйте, например так:

    var items = new List<KeyValuePair<string, string>>();
    
    for (int i = 0; i < Prox.Length; i++)
    {
    	items.Add(new KeyValuePair<string, string>(Prox[i], accitem[i]));
    }
    
    // с использованием Parallel, если массивы очень огромные
    // Parallel.For(0, prox.Length, i => items.Add(new KeyValuePair<string, string>(Prox[i], accitem[i])));
    
    Parallel.ForEach(items, options, p => indieroyale(p.Key, p.Value));


    Можно заменить KeyValuePair на свой класс, с двумя полями string, сути это не меняет.

    UPD: Да и вообще, зачем Вам Parallel.ForEach? Делайте все через Parallel.For, без всяких объединений:

    Parallel.For(0, Prox.Length, options, i => indieroyale(Prox[i], accitem[i]));
    Ответ написан
    4 комментария
  • Как сделать окно приложения C# невидимым и не показывать в трее?

    andrewpianykh
    @andrewpianykh
    Можно создать WPF приложение.
    В конструкторе главного окна добавить следущее:

    public MainWindow()
    {
    	InitializeComponent();
    
    	ShowInTaskbar = false;
    	Hide();
    }
    Ответ написан
    Комментировать
  • Как привязать отображаемые данные в DataGrid(wpf) к БД?

    andrewpianykh
    @andrewpianykh
    dataGrid.ItemsSource = dataFromMySql;
    
    var timer = new System.Windows.Threading.DispatcherTimer();
    timer.Tick += (oe,e)=> dataGrid.Items.Refresh(); 
    /* или  */
    /* timer.Tick += (oe,e)=> { dataGrid.ItemsSource = null; dataGrid.ItemsSource = dataFromMySql; } */
    timer.Interval = new TimeSpan(0,0,10);
    timer.Start();
    Ответ написан
    Комментировать
  • Как обработать все ошибки (перехваченные и неперехваченные) в ASP.Net MVC?

    andrewpianykh
    @andrewpianykh
    Я предпочитаю следующий подход:

    1. Создаем контроллер ErrorController, например так:

    public class ErrorController
    {
    	public virtual ActionResult BadRequest()
    	{
    		return View();
    	}
    
    	public virtual ActionResult Forbidden()
    	{
    		return View();
    	}
    
    	public virtual ActionResult Index()
    	{
    		return View();
    	}
    
    	public virtual ActionResult NotFound()
    	{
    		return View();
    	}
    }


    2. Добавляем вьюхи

    3. Создаем свой расширенный HandleErrorAttribute, например так:

    public class ExtHandleErrorAttribute : HandleErrorAttribute
    {
    	//private readonly ILogger logger;
    
    	public ExtHandleErrorAttribute(/*ILogger logger*/)
    	{
    		//this.logger = logger;
    	}
    
    	public override void OnException(ExceptionContext filterContext)
    	{
    		if (filterContext.ExceptionHandled || !filterContext.HttpContext.IsCustomErrorEnabled)
    		{
    			return;
    		}
    
    		if (new HttpException(null, filterContext.Exception).GetHttpCode() != 500)
    		{
    			return;
    		}
    
    		if (!ExceptionType.IsInstanceOfType(filterContext.Exception))
    		{
    			return;
    		}
    
    		if (filterContext.HttpContext.Request.Headers["X-Requested-With"] == "XMLHttpRequest")
    		{
    			filterContext.Result = new JsonResult
    			{
    				JsonRequestBehavior = JsonRequestBehavior.AllowGet,
    				Data = new
    				{
    					error = true,
    					message = filterContext.Exception.Message
    				}
    			};
    		}
    		else
    		{
    			var controllerName = (string)filterContext.RouteData.Values["controller"];
    			var actionName = (string)filterContext.RouteData.Values["action"];
    			var model = new HandleErrorInfo(filterContext.Exception, controllerName, actionName);
    
    			filterContext.Result = new ViewResult
    			{
    				ViewName = View,
    				MasterName = Master,
    				ViewData = new ViewDataDictionary<HandleErrorInfo>(model),
    				TempData = filterContext.Controller.TempData
    			};
    		}
    
    		//var e = filterContext.Exception;
    		//logger.Error(e, e.Message);
    
    		filterContext.ExceptionHandled = true;
    		filterContext.HttpContext.Response.Clear();
    		filterContext.HttpContext.Response.StatusCode = 500;
    		filterContext.HttpContext.Response.TrySkipIisCustomErrors = true;
    	}
    }


    4. Регистрируем глобальный фильтр:
    public class FilterConfig
    {
    	public static void RegisterGlobalFilters(GlobalFilterCollection filters)
    	{
    		var extHandleErrorAttribute = DependencyResolver.Current.GetService<ExtHandleErrorAttribute>();// new ExtHandleErrorAttribute();
    		filters.Add(extHandleErrorAttribute);
    	}
    }


    5. В Global.asax.cs добавляем метод Application_Error:

    protected void Application_Error(object sender, EventArgs e)
    {
    	var httpContext = ((MvcApplication)sender).Context;
    
    	var currentRouteData = RouteTable.Routes.GetRouteData(new HttpContextWrapper(httpContext));
    	var currentController = " ";
    	var currentAction = " ";
    
    	if (currentRouteData != null)
    	{
    		if (currentRouteData.Values["controller"] != null && !String.IsNullOrEmpty(currentRouteData.Values["controller"].ToString()))
    		{
    			currentController = currentRouteData.Values["controller"].ToString();
    		}
    
    		if (currentRouteData.Values["action"] != null && !String.IsNullOrEmpty(currentRouteData.Values["action"].ToString()))
    		{
    			currentAction = currentRouteData.Values["action"].ToString();
    		}
    	}
    
    	var ex = Server.GetLastError();
    
    	var controller = new ErrorController();
    	var routeData = new RouteData();
    	var action = "Index";
    
    	if (ex is HttpException)
    	{
    		var httpEx = ex as HttpException;
    
    		switch (httpEx.GetHttpCode())
    		{
    			case 404:
    				action = "NotFound";
    				break;
    
    			case 403:
    				action = "Forbidden";
    				break;
    
    			case 400:
    				action = "BadRequest";
    				break;
    
    			default:
    				action = "Index";
    				//var logger = DependencyResolver.Current.GetService<ILogger>();
    				//logger.Error(ex, ex.Message);
    				break;
    		}
    	}
    
    	httpContext.ClearError();
    	httpContext.Response.Clear();
    	httpContext.Response.StatusCode = ex is HttpException ? ((HttpException)ex).GetHttpCode() : 500;
    	httpContext.Response.TrySkipIisCustomErrors = true;
    	routeData.Values["controller"] = "Error";
    	routeData.Values["action"] = action;
    
    	controller.ViewData.Model = new HandleErrorInfo(ex, currentController, currentAction);
    	((IController)controller).Execute(new RequestContext(new HttpContextWrapper(httpContext), routeData));
    }


    6. В web.config добавляем в system.web
    <customErrors mode="On" />

    также в system.webServer можно добавить:

    <httpErrors>
      <remove statusCode="400" subStatusCode="-1" />
      <remove statusCode="403" subStatusCode="-1" />
      <remove statusCode="502" subStatusCode="-1" />
      <remove statusCode="501" subStatusCode="-1" />
      <remove statusCode="500" subStatusCode="-1" />
      <remove statusCode="404" subStatusCode="-1" />
      <error statusCode="400" prefixLanguageFilePath="" path="/Error/BadRequest" responseMode="ExecuteURL" />
      <error statusCode="404" prefixLanguageFilePath="" path="/Error/NotFound" responseMode="ExecuteURL" />
      <error statusCode="500" prefixLanguageFilePath="" path="/Error" responseMode="ExecuteURL" />
      <error statusCode="501" prefixLanguageFilePath="" path="/Error" responseMode="ExecuteURL" />
      <error statusCode="502" prefixLanguageFilePath="" path="/Error" responseMode="ExecuteURL" />
      <error statusCode="403" prefixLanguageFilePath="" path="/Error/Forbidden" responseMode="ExecuteURL" />
    </httpErrors>
    Ответ написан
    Комментировать
  • Где хранить конфигурацию программы C#.NET?

    andrewpianykh
    @andrewpianykh
    Используйте бинарную сериализацию / BinaryFormatter
    Ответ написан
    Комментировать
  • Как организовать хранение данных в c# WPF (программа - заучивание иностранных слов)?

    andrewpianykh
    @andrewpianykh
    Из нативного я бы рекомендовал Microsoft SQL Server Compact + EntityFramework.
    Иначе, как уже писали выше, XML/JSON. По удобству работы в целом без разницы, для XML - Linq to XML, для JSON - JSON.NET
    Ответ написан
    Комментировать