[C#]使用Process的StandardInput与StandardOutput写入读取控制台数据



本文为原创文章、源代码为原创代码,如转载/复制,请在网页/代码处明显位置标明原文名称、作者及网址,谢谢!



开发工具:VS2017

语言:C#

DotNet版本:.Net FrameWork 4.0及以上

一、为了演示使用程序读取控制台数据,现在需要编写一个控制台程序,代码如下:

using System;

namespace Test
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Hello World!");
            string content = Console.ReadLine();
            if(content.ToUpper() == "TEST")
            {
                Console.WriteLine("You have type correctly.\r\nCongratulation!");
            }
            else
            {
                Console.WriteLine("Sorry,Uncorrectly!\r\nSee you later.");
            }
        }
    }
}

这段代码的作用是:

1)在控制台输出“Hello World!”;

2)当输出“Test”(不管大小写),则输出:

You have type correctly.

Congratulation!

3)当输出其他时,则输出:

Sorry,Uncorrectly!

See you later.

以上是必备的应用程序,如果不使用该程序,可以使用System32文件夹下的cmd.exe来当做控制台应用程序;

二、将以上生成的程序Test.exe拷贝到D盘根目录下;

三、新建一个控制台应用程序(MainConsoleApp),来操作之前的控制台应用程序,并编写以下代码:

using System;
using System.Diagnostics;

namespace MainConsoleApp
{
    class Program
    {
        static void Main(string[] args)
        {
            Process proc = new Process
            {
                StartInfo = new ProcessStartInfo
                {
                    FileName = @"D:\test.exe",
                    UseShellExecute = false,
                    CreateNoWindow = true,
                    RedirectStandardInput = true,
                    RedirectStandardOutput = true
                }
            };
            proc.Start();
            proc.StandardInput.WriteLine("Test");
            string line = null;
            while (!proc.StandardOutput.EndOfStream)
            {
                line +=  proc.StandardOutput.ReadLine() + Environment.NewLine;
            }
            Console.WriteLine(line);
            proc.WaitForExit();

            //再次启动
            proc.Start();
            proc.StandardInput.WriteLine("T");
            string content = proc.StandardOutput.ReadToEnd();
            Console.WriteLine(content);
            proc.WaitForExit();

            Console.ReadKey();
        }
    }
}

代码作用简介:

ProcessStartInfo.FileName:要启动的应用程序名称;

ProcessStartInfo.UseShellExecute:要重定向 IO流,Process对象必须将 UseShellExecute属性设置为false;

ProcessStartInfo.CreateNoWindow:是否以没有窗体的模式创建应用程序,默认为false,即有窗体,如为true,即隐藏窗体。在这里不设置该值也可以;

ProcessStartInfo.RedirectStandardInput:标准输入流的重定向,重定向至Process,我们可以通过Process.StandardInput.WriteLine将数据写入标准流;

ProcessStartInfo.RedirectStandardOutput:与RedirectStandardInput相反,这是标准输出流的重定向,我们可以通过Process.RedirectStandardOutput.ReadLine等方法读取标准流数据。

Process.StandardInput.WriteLine:将数据写入标准流;

Process.StandardOutput.ReadLine(或ReadToEnd):从标准流读取数据。

四、该程序将向Test.exe写入数据,并从Test.exe读回数据,这里使用了重定向技术,运行结果如下:

我们可以看到,原来是Test.exe的程序,所有的数据操作都进行了重定向,直接在MainConsoleApp.exe进行了输入输出。

这个技术不仅仅可以用于以上的示例,还可以用于其他具有控制台输入输出的程序,如cmd.exe,这里不进行举例,自己进行试验即可。

时间: 2024-10-17 09:40:53

[C#]使用Process的StandardInput与StandardOutput写入读取控制台数据的相关文章

net快速写入/读取大量数据Postgresql

Postgresql快速写入/读取大量数据 http://www.cnblogs.com/podolski/p/7152144.html 环境及测试 使用.net驱动npgsql连接post数据库.配置:win10 x64, i5-4590, 16G DDR3, SSD 850EVO. postgresql 9.6.3,数据库与数据都安装在SSD上,默认配置,无扩展. CREATE TABLE public.mesh ( x integer NOT NULL, y integer NOT NUL

JAVA笔记-如何向Excel表单中高效的批量写入百万条数据

今天,一朋友问我使用JAVA有没有什么办法导出百万级的数据到Excel工作表. 当时我的第一个念头就是这真的是一个好疯狂的念头.然后就想假如真的有这样类似的需求,我自己应该怎么做呢? ps: 首先科普一下基础知识 Excel 2003及以下的版本.一张表最大支持65536行数据,256列.也就是说excel2003完全不可能满足百万数据导出的需求. Excel 2007-2010版本.一张表最大支持1048576行,16384列: 笔者使用的是office 2010,更高的版本笔者没有使用过,暂

Android中写入读取XML

获取XML文件的基本思路是,通过getResources().getXml()获的XML原始文件,得到XmlResourceParser对象,通过该对象来判断是文档的开头还是结尾,是某个标签的开始还是结尾,并通过一些获取属性的方法来遍历XML文件,从而访问XML文件的内容,下面是一个访问XML文件内容的例子,并将内容更显示在一个TextView上 数据写入xml: ReadXMLTest.java [java] view plaincopy //xml数据生成 private String Wr

ObjectOutputStream 追加写入读取错误

摘自http://blog.csdn.net/mitkey/article/details/50274543 问题描述: 用类ObjectOutputStream向文件写读对象时,碰到一个问题:新建一个文件,用输出流ObjectOutputStream向文件连续写几个对象,关闭输出流,然 后读取,这些对象都可以读出:这时在向该文件增加对象,新写的对象就读不出了 问题出现的原因: ObjectOutputStream建立后第一次写入一个对象时, 会在对象数据前写入一些标志的数据"AC ED  00

解决磁盘只读、介质受写入保护或者不能写入和删除数据的问题

我的硬盘有2块,一个固态,一个普通硬盘,最近普通硬盘被我莫名的搞成了只读甚至在格式化的时候还提示"介质受写入保护**",试了N多种方法都不行,最后还是在国外的网站上找到了解决方法,虽然我英文烂的很,可还是硬着头皮找到了.....现在记录下过程供遇到同种情况的伙伴参考.(另外说明下:国内的搜索简直无法直视,搜出的答案基本都是一个样!!注册表方法就不要尝试了,根本没用,我现在要说的是利用系统自带的diskpart命令进行解决.不知道U盘或者移动硬盘是否有效,反正大家可以试试.)PS:一定要

PHP 文件写入或追加数据

PHP file_put_contents() 函数是一次性向文件写入字符串或追加字符串内容的最合适选择. file_put_contents() file_put_contents() 函数用于把字符串写入文件,成功返回写入到文件内数据的字节数,失败则返回 FALSE. 语法: int file_put_contents ( string filename, string data [, int flags [, resource context]] ) 参数说明: 参数 说明 filenam

MO拆分计划行程序中写入PRODUCTIONORDERS表数据出现重复导致报错(BUG)20180502

错误提示:ORA-00001: 违反唯一约束条件 (ABPPMGR.C0248833319_6192)ORA-06512: 在 "STG.FP_MO_SPLIT", line 199  ORA-06512: 在 "STG.FP_MO_SPLIT", line 1318 错误描述:MO拆分计划行程序中写入PRODUCTIONORDERS表数据出现重复导致报错(BUG) 存储过程:FP_MO_SPLIT 解决方法: 原文地址:https://www.cnblogs.co

Java读取CSV数据并写入txt文件

读取CSV数据并写入txt文件 package com.vfsd; import java.io.BufferedWriter; import java.io.File; import java.io.FileWriter; import java.io.IOException; import com.csvreader.CsvReader; /****************************************************************************

C# 创建 写入 读取 excel

public static void CreateExcelFile(string FileName, List<UUser> luu) { if (FileName.Split('.')[FileName.Split('.').Length - 1] == "xlsx")//如果是2007版以后 { //create object Nothing = System.Reflection.Missing.Value; var app = new Excel.Applicat