编程打卡:半自动Unix/Linux基础 作业糊弄器!(逃
Posted 松坂制糖厂
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了编程打卡:半自动Unix/Linux基础 作业糊弄器!(逃相关的知识,希望对你有一定的参考价值。
因为学校的Unix/Linux的作业只是做实验报告,简单的将每条命令全部输入一遍,然后再截屏,很多时间都花在截屏上面,很累,所以就用Python做了这个小玩意儿。
import keyboard,win32gui
import time
from PIL import ImageGrab
windowTitile = "窗口的名字"
handle = win32gui.FindWindow(None,windowTitile)
left, top, right, bottom = win32gui.GetWindowRect(handle)
win32gui.SetForegroundWindow(handle)
fname = 1
with open("commands.txt","rt") as f:
for line in f:
keyboard.write(line)
time.sleep(0.5)
img_ready = ImageGrab.grab((left,top,right,bottom))
img_ready.save(str(fname)+ ".png")
fname += 1
具体的解释一下,使用 win32gui
来找到输入命令的窗口,获取窗口的大小位置,并将焦点移至窗口,循环从文件中读取每个命令,然后用keyboard
在窗口中执行,等待0.5秒大约执行好了,就使用ImageGrab
根据前面获取的窗口位置截图。
fname
只是为了让给每个截图不同的名字防止重名然后覆盖。
需要注意的是,在Windows设置缩放的时候,并不能准确的获得到窗口位置用ImageGrab截图,原因我懒得想,不过你就短暂的调成100%缩放一会儿也行。
此外,发现把图片插入MS Word,加上文字排版,需要的时间同样也不短,最终还是没有怎么节省时间。
然后感觉自己好废,说的每日编程,但是看蓝牙也还是没看懂个啥,没法上手写,简单改了改自己博客的CSS,但也不方便发出来,只好拿出自己之前写的程序来凑一次每日编程打卡。
啊啊,对了,我能这样找到窗口然后输入是因为我是在Windows中使用了WSL(Windows Subsystem Linux),直接将命令输入Windows Terminal中的,如果你是在虚拟机里面的话是不行的,焦点切换到虚拟机内,keyboard write操作似乎就不工作了,或许可以ssh进去。
或者如果直接在Linux中运行的话,也要找相应的办法来获得窗口的位置和截图,不过这也很容易,我相信你可以做到的。
关于UNIX/Linux下安装《UNIX环境高级编程》源代码的问题
《UNIX环境高级编程(第三版)》是一本广为人知的unix系统编程书籍。
但是,书中的代码示例,要想正确的编译运行,要先做好准备工作:
1.下载源代码
传送门:http://apuebook.com/code3e.html
2.解压源代码
tar xf src.3e.tar.gz
3.安装libbsd-devel,不然编译的时候回报错
yum install libbsd-devel -y
4.编译
cd apue.3e/
make
cp ./include/apue.h /usr/include/
cp ./lib/libapue.a /usr/local/lib/
cp ./lib/libapue.a /usr/lib/
5.自定义错误头文件
vim /usr/include/myerr.h
#include <errno.h> /* for definition of errno */
#include <stdarg.h> /* ISO C variable aruments */
static void err_doit(int, int, const char *, va_list);
/*
* Nonfatal error related to a system call.
* Print a message and return.
*/
void
err_ret(const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
err_doit(1, errno, fmt, ap);
va_end(ap);
}
/*
* Fatal error related to a system call.
* Print a message and terminate.
*/
void
err_sys(const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
err_doit(1, errno, fmt, ap);
va_end(ap);
exit(1);
}
/*
* Fatal error unrelated to a system call.
* Error code passed as explict parameter.
* Print a message and terminate.
*/
void
err_exit(int error, const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
err_doit(1, error, fmt, ap);
va_end(ap);
exit(1);
}
/*
* Fatal error related to a system call.
* Print a message, dump core, and terminate.
*/
void
err_dump(const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
err_doit(1, errno, fmt, ap);
va_end(ap);
abort(); /* dump core and terminate */
exit(1); /* shouldn‘t get here */
}
/*
* Nonfatal error unrelated to a system call.
* Print a message and return.
*/
void
err_msg(const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
err_doit(0, 0, fmt, ap);
va_end(ap);
}
/*
* Fatal error unrelated to a system call.
* Print a message and terminate.
*/
void
err_quit(const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
err_doit(0, 0, fmt, ap);
va_end(ap);
exit(1);
}
/*
* Print a message and return to caller.
* Caller specifies "errnoflag".
*/
static void
err_doit(int errnoflag, int error, const char *fmt, va_list ap)
{
char buf[MAXLINE];
vsnprintf(buf, MAXLINE, fmt, ap);
if (errnoflag)
snprintf(buf+strlen(buf), MAXLINE-strlen(buf), ": %s",
strerror(error));
strcat(buf, "\n");
fflush(stdout); /* in case stdout and stderr are the same */
fputs(buf, stderr);
fflush(NULL); /* flushes all stdio output streams */
}
测试
写个程序
vim myls.c
#include "apue.h"
#include "myerr.h"
#include <dirent.h>
int
main(int argc, char *argv[])
{
DIR *dp;
struct dirent *dirp;
if (argc != 2)
err_quit("usage: ls directory_name");
if ((dp = opendir(argv[1])) == NULL)
err_sys("can’t open %s", argv[1]);
while ((dirp = readdir(dp)) != NULL)
printf("%s\n", dirp->d_name);
closedir(dp);
exit(0);
}
编译
gcc myls.c
执行
./a.out /root
以上是关于编程打卡:半自动Unix/Linux基础 作业糊弄器!(逃的主要内容,如果未能解决你的问题,请参考以下文章