编程打卡:半自动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基础 作业糊弄器!(逃的主要内容,如果未能解决你的问题,请参考以下文章

我的编码之旅

我的编码之旅

我的编码之旅

Python Socket编程基础篇

网络编程基础day08:socke编程入门

python学习笔记-scoket编程基础