繁体   English   中英

CGI 脚本中的 NLTK function 为空 output

[英]Empty output for NLTK function in CGI script

我想在 CGI 脚本中使用 python NLTK 库的 function 来标记一些文本,通过 WEB 收到。

如果我只是使用:

someamountoftext = "someamountoftext someamountoftext someamountoftext"

然后

 nltk.word_tokenize(someamountoftext)

或者

nltk.sent_tokenize(someamountoftext)

它会起作用。

但是:如果我使用这个:

#!C:\Users\HP\AppData\Local\Programs\Python\Python310-32\python.exe
import os
import urllib.parse
import nltk
query_dict = urllib.parse.parse_qs(os.environ['QUERY_STRING'])

def tknz_wrd(someamountoftext):
return(nltk.word_tokenize(someamountoftext))


print("Content-Type: text/html\n")

print (tknz_wrd(someamountoftext))

(以上是我所有的单文件代码,没有框架之类的)。

它不会在屏幕上打印任何内容。 没有错误,只是白色的浏览器屏幕。 当然,我尝试过手动输入,例如:

http://localhost/speciallocationforproject/local/tokenize/morgot.py?someamountoftext=somekindoftext

它没有改变任何东西。

morgot.py - 我的 CGI 文件的名称。

我的错误在哪里? 和/或如何通过 WEB 进行标记化?

我使用:Apache/2.4.53 (Win64) OpenSSL/1.1.1n PHP/7.4.28

python 3.10.4

问题解决了。 所以我犯了一些错误,正确的代码是:


#!C:\Users\HP\AppData\Local\Programs\Python\Python310-32\python.exe

import os
import urllib.parse
import nltk

query_dict = urllib.parse.parse_qs(os.environ[‘QUERY_STRING’])
input_something = str(query_dict[‘someamountoftext’])[2: -2]
def tknz_wrd(someamountoftext):
return(nltk.word_tokenize(someamountoftext))

print(“Content-Type: text/html\n”)

print (tknz_wrd(input_something))

它处理从浏览器行收到的数据,例如:http://localhost/speciallocation/local/tokenize/morgot.py?someamountoftext=Enter%20your%20text%20here

morgot.py - CGI 文件的名称。

'?someamountoftext=' 这是将数据输入变量的方式

%20 - 浏览器行中的空格键。

Output:['输入','你的','文本','这里']

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM