- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想从 sys.stdin 读取两个不同的文件,我可以读取和写入文件,但第一个和第二个文件没有分离。
当我在 cmd win 10 和 python 3.6 上运行以下代码时:
D:\digit>cat s.csv s2.csv
结果是:
123451234567
I can print both files.
My python code is:
import sys
import numpy as np
train=[]
test=[]
#Assume below code is function 1 which just and must read s.csv
reader = sys.stdin.readlines()
for row in reader:
train.append(int(row[0]))
train = np.array(train)
print(train)
#I need some thing here to make separation
#sys.stdin.close()
#sys.stdin = sys.__stdin__
#sys.stdout.flush()
#Assume below code is function 2 which just and must read s2.csv
reader = sys.stdin.readlines()
for row in reader:
test.append(int(row[0]))
test = np.array(test)
print(test)
我在 cmd 提示符下运行以下命令:
D:\digit>cat s.csv s2.csv | python pytest.py
结果是:
[1 2 3 4 5 1 2 3 4 5 6 7]
[]
我需要为下一个文件重置 sys.stdin 吗?我使用了以下内容,但没有一个是答案:
sys.stdin.close()
sys.stdin = sys.__stdin__
sys.stdout.flush()
提前感谢您提供的任何帮助。
最佳答案
让我尝试解释一下。
d:\digit>cat s.csv s2.csv
只有 1 个输出,而不是 2 个。它的作用是将 file1
的内容“流式传输”到 stdout
,然后“流式传输”file2 的内容
到 stdout
,没有任何暂停或分隔符!!
因此只有 1 个输出“流”,然后您可以使用 | 进行重定向。到你的 pyton 脚本:
| pytest.py
因此,pytest.py
将接收 1 个输入“流”,它不知道更好或更多。
如果你想通过pytest.py
单独处理文件,可以执行以下操作
D:\digit>cat s.csv | python pytest.py # process the first file
D:\digit>cat s2.csv | python pytest.py # process the second file
或单行:
D:\digit>cat s.csv | python pytest.py && cat s2.csv | python pytest.py
请记住,pytest.py
实际上运行了两次。因此,您需要为此调整您的 python 脚本。
但是当你编辑 python 脚本时...
你应该做什么:如果您希望 pytest.py 中包含这两个文件,那么您应该编写一些代码来读取 python 脚本中的这两个文件。如果是csv结构化数据,那么看看csv module for reading and writing csv files
[根据评论进行编辑:]
I could read multiple files it by pandas "pd.read_csv" , but my problem is how can I do it by sys.stdin?
您真的应该质疑为什么您如此专注于使用 stdin
。从 python 脚本中读取它可能会更有效。
如果您必须使用stdin
,那么您可以部署各种但在Python外部的页眉、页脚、分隔符。一旦定义了这个并且能够执行此操作,您就可以更改 python 中的代码来执行各种功能,具体取决于从 stdin
接收到的页眉/页脚/分隔符。
这一切听起来有点复杂并且容易出错。我强烈建议您重新考虑使用 stdin 作为脚本的输入。或者,请使用您面临的限制您使用标准输入的技术要求和限制来更新您的问题。
[根据评论进行编辑:]
I want to load these files I Hadoop ecosystem and I am using Hadoop streaming for that
不知何故,您需要向您的 python 脚本发出“信号”,表明它正在处理带有新信息的新文件。
假设您有 2 个文件,第一行需要是某种指示文件的“ header ”,以及需要对其余数据执行哪个函数,直到收到新的“ header ”。
因此,假设您的“训练”数据以行 @is_train@
为前缀,而您的“测试”数据以行 @is_test@
为前缀
如何在您的环境中做到这一点,不属于此问题的范围
现在重定向到标准输入将在数据之前发送这两个 header 。你可以使用 python 来检查这些,例如:
import sys
import numpy as np
train=[]
test=[]
is_train = False
is_test = False
while True:
line = sys.stdin.readline()
if '@stop@' in line:
break
if '@is_train@' in line:
is_train = True
is_test = False
continue
if '@is_test@' in line:
is_train = False
is_test = True
continue
#if this is csv data, you might want to split on ,
line = line.split(',')
if is_train:
train.append(int(line[0]))
if is_test:
test.append(int(line[0]))
test = np.array(test)
train = np.array(train)
print(train)
print(test)
正如您在代码中看到的,您还需要一个“页脚”来确定数据何时结束,在本例中选择了@stop@
。
发送页眉/页脚的一种方法可能是:
D:\digit>cat is_train.txt s.csv is_test.txt s2.csv stop.txt | python pytest.py
以及三个额外文件,仅包含适当的页眉或页脚
关于python - 如何在Python中通过sys.stdin读取两个不同的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48985922/
我需要将文本放在 中在一个 Div 中,在另一个 Div 中,在另一个 Div 中。所以这是它的样子: #document Change PIN
奇怪的事情发生了。 我有一个基本的 html 代码。 html,头部, body 。(因为我收到了一些反对票,这里是完整的代码) 这是我的CSS: html { backgroun
我正在尝试将 Assets 中的一组图像加载到 UICollectionview 中存在的 ImageView 中,但每当我运行应用程序时它都会显示错误。而且也没有显示图像。 我在ViewDidLoa
我需要根据带参数的 perl 脚本的输出更改一些环境变量。在 tcsh 中,我可以使用别名命令来评估 perl 脚本的输出。 tcsh: alias setsdk 'eval `/localhome/
我使用 Windows 身份验证创建了一个新的 Blazor(服务器端)应用程序,并使用 IIS Express 运行它。它将显示一条消息“Hello Domain\User!”来自右上方的以下 Ra
这是我的方法 void login(Event event);我想知道 Kotlin 中应该如何 最佳答案 在 Kotlin 中通配符运算符是 * 。它指示编译器它是未知的,但一旦知道,就不会有其他类
看下面的代码 for story in book if story.title.length < 140 - var story
我正在尝试用 C 语言学习字符串处理。我写了一个程序,它存储了一些音乐轨道,并帮助用户检查他/她想到的歌曲是否存在于存储的轨道中。这是通过要求用户输入一串字符来完成的。然后程序使用 strstr()
我正在学习 sscanf 并遇到如下格式字符串: sscanf("%[^:]:%[^*=]%*[*=]%n",a,b,&c); 我理解 %[^:] 部分意味着扫描直到遇到 ':' 并将其分配给 a。:
def char_check(x,y): if (str(x) in y or x.find(y) > -1) or (str(y) in x or y.find(x) > -1):
我有一种情况,我想将文本文件中的现有行包含到一个新 block 中。 line 1 line 2 line in block line 3 line 4 应该变成 line 1 line 2 line
我有一个新项目,我正在尝试设置 Django 调试工具栏。首先,我尝试了快速设置,它只涉及将 'debug_toolbar' 添加到我的已安装应用程序列表中。有了这个,当我转到我的根 URL 时,调试
在 Matlab 中,如果我有一个函数 f,例如签名是 f(a,b,c),我可以创建一个只有一个变量 b 的函数,它将使用固定的 a=a1 和 c=c1 调用 f: g = @(b) f(a1, b,
我不明白为什么 ForEach 中的元素之间有多余的垂直间距在 VStack 里面在 ScrollView 里面使用 GeometryReader 时渲染自定义水平分隔线。 Scrol
我想知道,是否有关于何时使用 session 和 cookie 的指南或最佳实践? 什么应该和什么不应该存储在其中?谢谢! 最佳答案 这些文档很好地了解了 session cookie 的安全问题以及
我在 scipy/numpy 中有一个 Nx3 矩阵,我想用它制作一个 3 维条形图,其中 X 轴和 Y 轴由矩阵的第一列和第二列的值、高度确定每个条形的 是矩阵中的第三列,条形的数量由 N 确定。
假设我用两种不同的方式初始化信号量 sem_init(&randomsem,0,1) sem_init(&randomsem,0,0) 现在, sem_wait(&randomsem) 在这两种情况下
我怀疑该值如何存储在“WORD”中,因为 PStr 包含实际输出。? 既然Pstr中存储的是小写到大写的字母,那么在printf中如何将其给出为“WORD”。有人可以吗?解释一下? #include
我有一个 3x3 数组: var my_array = [[0,1,2], [3,4,5], [6,7,8]]; 并想获得它的第一个 2
我意识到您可以使用如下方式轻松检查焦点: var hasFocus = true; $(window).blur(function(){ hasFocus = false; }); $(win
我是一名优秀的程序员,十分优秀!