Пользователь выхода от XP Победы программно в C#

Вот автоматическая компоновка с большим количеством групп (случайных поддельных данных) и игра с grouped.get_group(key) покажет вам, как делать более элегантные сюжеты.

import pandas as pd
from numpy.random import randint
import matplotlib.pyplot as plt


df = pd.DataFrame(randint(0,10,(200,6)),columns=list('abcdef'))
grouped = df.groupby('a')
rowlength = grouped.ngroups/2                         # fix up if odd number of groups
fig, axs = plt.subplots(figsize=(9,4), 
                        nrows=2, ncols=rowlength,     # fix as above
                        gridspec_kw=dict(hspace=0.4)) # Much control of gridspec

targets = zip(grouped.groups.keys(), axs.flatten())
for i, (key, ax) in enumerate(targets):
    ax.plot(grouped.get_group(key))
    ax.set_title('a=%d'%key)
ax.legend()
plt.show()

enter image description here [/g0]

25
задан dbkk 27 January 2009 в 17:10
поделиться

6 ответов

Вы можете P / Invoke ExitWindowsEx:

http://www.pinvoke.net/default.aspx/user32/ExitWindowsEx.html

Собираем все вместе:

using System.Runtime.InteropServices;
class Class1
{
    [DllImport("user32.dll")]
    static extern bool ExitWindowsEx(uint uFlags, uint dwReason);

    [STAThread]
    static void Main(string[] args)
    {
        ExitWindowsEx(ExitWindows.LogOff, ShutdownReason.MajorOther | ShutdownReason.MinorOther); 
    }
}

[Flags]
public enum ExitWindows : uint
{
   // ONE of the following five:
   LogOff = 0x00,
   ShutDown = 0x01,
   Reboot = 0x02,
   PowerOff = 0x08,
   RestartApps = 0x40,
   // plus AT MOST ONE of the following two:
   Force = 0x04,
   ForceIfHung = 0x10,
}

[Flags]
enum ShutdownReason : uint
{
    MajorApplication = 0x00040000,
    MajorHardware = 0x00010000,
    MajorLegacyApi = 0x00070000,
    MajorOperatingSystem = 0x00020000,
    MajorOther = 0x00000000,
    MajorPower = 0x00060000,
    MajorSoftware = 0x00030000,
    MajorSystem = 0x00050000,

    MinorBlueScreen = 0x0000000F,
    MinorCordUnplugged = 0x0000000b,
    MinorDisk = 0x00000007,
    MinorEnvironment = 0x0000000c,
    MinorHardwareDriver = 0x0000000d,
    MinorHotfix = 0x00000011,
    MinorHung = 0x00000005,
    MinorInstallation = 0x00000002,
    MinorMaintenance = 0x00000001,
    MinorMMC = 0x00000019,
    MinorNetworkConnectivity = 0x00000014,
    MinorNetworkCard = 0x00000009,
    MinorOther = 0x00000000,
    MinorOtherDriver = 0x0000000e,
    MinorPowerSupply = 0x0000000a,
    MinorProcessor = 0x00000008,
    MinorReconfig = 0x00000004,
    MinorSecurity = 0x00000013,
    MinorSecurityFix = 0x00000012,
    MinorSecurityFixUninstall = 0x00000018,
    MinorServicePack = 0x00000010,
    MinorServicePackUninstall = 0x00000016,
    MinorTermSrv = 0x00000020,
    MinorUnstable = 0x00000006,
    MinorUpgrade = 0x00000003,
    MinorWMI = 0x00000015,

    FlagUserDefined = 0x40000000,
    FlagPlanned = 0x80000000
}
41
ответ дан Kev 15 October 2019 в 15:17
поделиться

Попытайтесь назвать API-функцию "ExitWindowsEx" с постоянным "EWX_LOGOFF" или 0. Руководство API говорит мне, что второй параметр проигнорирован. Например,

//The import
using System.Runtime.InteropServices;

// The declaration
[DllImport("user32.dll")]
public static extern int ExitWindowsEx(int uFlags, int dwReserved);

// The call
 ExitWindowsEx(0, 0);
14
ответ дан Cerebrus 15 October 2019 в 15:17
поделиться
3
ответ дан gkrogers 15 October 2019 в 15:17
поделиться

Или можно просто звонить:

shutdown.exe -l -t 0

, Если Вы хотите простой способ. Я использую ExitWindowsEx сам.

3
ответ дан kmatyaszek 15 October 2019 в 15:17
поделиться

Вы не можете объединить -l с -t по некоторым причинам, поэтому они не будут работать. Единственный подход, по-видимому, - вышеупомянутый P / Invoke.

2
ответ дан Didier Ghys 15 October 2019 в 15:17
поделиться

Для полноты картины, самый простой способ, который я нашел, - это вызвать Shutdown.exe (входит в состав Windows).

Process.Start("shutdown.exe", "-l -t 0");

Это ответ, который предложил Церебрус, только в форме C #.

6
ответ дан 28 November 2019 в 18:10
поделиться