获取在C#中输入控制台输入所花费的时间

时间:2018-07-27 18:50:08

标签: c# console stopwatch

我有一种方法,可以使用Console.ReadLine()

从控制台获取输入

我想知道用户写输入花了多长时间。

我知道我可以用StopWatch记录时间,但是我只想记录第一个按下键和回车键之间的时间。

我该怎么办?

使用Google翻译器翻译

2 个答案:

答案 0 :(得分:4)

版本1

Stopwatch stopWatch = new Stopwatch();

// Read first key pressed, then start stopwatch
var firstChar = Console.ReadKey();
stopWatch.Start();

// Read the rest followed by enter, then stop stopwatch
var restOfString = Console.ReadLine();
stopWatch.Stop();

// Join first char and rest of string together
var wholeString = string.Concat(firstChar.KeyChar, restOfString);
TimeSpan ts = stopWatch.Elapsed;

Console.WriteLine($"String entered: {wholeString}.");
Console.WriteLine($"It took {ts.Seconds} seconds.");
Console.ReadLine();

版本2

var keyInfo = new ConsoleKeyInfo();
var userInput = new StringBuilder();
var stopWatch = new Stopwatch();
var started = false;

do
{
     keyInfo = Console.ReadKey(false);

     if (started == false)
     {
          stopWatch.Start();
          started = true;
     }                

     switch (keyInfo.Key)
     {
          case ConsoleKey.Backspace:
              Console.Write(" \b");
              if(userInput.Length > 0) userInput.Remove(userInput.Length - 1, 1);
              break;
          // Stopping delete key outputting a space
          case ConsoleKey.Delete:
              Console.Write("\b");
              break;
          case ConsoleKey.Enter:
              break;
          default:
              userInput.Append(keyInfo.KeyChar);
              break;
    }
}
while (keyInfo.Key != ConsoleKey.Enter);

stopWatch.Stop();
TimeSpan ts = stopWatch.Elapsed;

var finalString = userInput.ToString();

Console.WriteLine();

Console.WriteLine($"String entered: {finalString}.");
Console.WriteLine($"It took {ts.Seconds} seconds.");

Console.ReadLine();

您可能要整理其他特殊字符,因为这只是解决您的特定问题。另请注意,您可以使用ReadKey(true)截取输入并停止任何输出。然后,您可以使用Console.Write()控制自己的输出。

版本3

为您提供选项,这里是一个截取并控制输出的版本。这是我的偏爱。

var keyInfo = new ConsoleKeyInfo();
var userInput = new StringBuilder();
var stopWatch = new Stopwatch();
var started = false;

do
{
    keyInfo = Console.ReadKey(true);

    if (started == false)
    {
        stopWatch.Start();
        started = true;
    }

    if (keyInfo.Key == ConsoleKey.Backspace)
    {
        Console.Write("\b \b");
        if(userInput.Length > 0) userInput.Remove(userInput.Length - 1, 1);
    }
    else if (keyInfo.Key == ConsoleKey.Enter)
    {
        // Do nothing
    }
    else if(Char.IsLetter(keyInfo.KeyChar) ||
            Char.IsDigit(keyInfo.KeyChar) ||
            Char.IsWhiteSpace(keyInfo.KeyChar) ||
            Char.IsPunctuation(keyInfo.KeyChar))

    {
        Console.Write(keyInfo.KeyChar);
        userInput.Append(keyInfo.KeyChar);
    }
} while (keyInfo.Key != ConsoleKey.Enter);

stopWatch.Stop();
TimeSpan ts = stopWatch.Elapsed;

var finalString = userInput.ToString();

Console.WriteLine();

Console.WriteLine($"String entered: {finalString}.");
Console.WriteLine($"It took {ts.Seconds} seconds.");

Console.ReadLine();

答案 1 :(得分:1)

怎么样呢?

while (!Console.KeyAvailable)
    Thread.Sleep(250);

var start = DateTime.Now;
var input = Console.ReadString();
var stop = DateTime.Now;