Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/20.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
用python创建动态论坛签名生成器_Python_Django_Image_Forum_Signature - Fatal编程技术网

用python创建动态论坛签名生成器

用python创建动态论坛签名生成器,python,django,image,forum,signature,Python,Django,Image,Forum,Signature,我搜索了又搜索,但我只找到了涉及php而不是python/django的解决方案。我的目标是创建一个允许用户输入字符串的网站(后端用python编码)。然后运行后端脚本并输出一个包含一些信息的字典。我想要的是使用字典中的信息将其绘制到服务器上的图像上,并将新图像提供给用户。我现在如何离线完成这项工作?我可以使用哪些库?任何关于我应该走的路线的建议都会很好 我还是一个新手,所以如果我的代码需要修改,请原谅我。到目前为止,我没有任何错误,但就像我说的,我不知道下一步要去哪里实现我的目标。任何提示都将

我搜索了又搜索,但我只找到了涉及php而不是python/django的解决方案。我的目标是创建一个允许用户输入字符串的网站(后端用python编码)。然后运行后端脚本并输出一个包含一些信息的字典。我想要的是使用字典中的信息将其绘制到服务器上的图像上,并将新图像提供给用户。我现在如何离线完成这项工作?我可以使用哪些库?任何关于我应该走的路线的建议都会很好

我还是一个新手,所以如果我的代码需要修改,请原谅我。到目前为止,我没有任何错误,但就像我说的,我不知道下一步要去哪里实现我的目标。任何提示都将不胜感激

这就是我想要的最终目标

这就是我到目前为止所做的(我在这里使用beautiful soup作为解析器。如果这太过分了,或者如果我做得不太好,请告诉我是否有更好的选择。谢谢):

我获取所需数字(这些是动态的)的url如下:

玩家的名字会跟在用户后面,所以举个例子

这是具有基本功能的代码,用于刮取网站:

from urllib import urlopen
from BeautifulSoup import BeautifulSoup

def get_avatar(player_name):
    '''Return the players avatar as a binary string.'''
    player_name = str(player_name)
    url = 'http://combat.nexon.net/Avatar/MyAvatar.srf?'
    url += 'GameName=CombatArms&CharacterID=' + player_name
    sock = urlopen(url)
    data = sock.read()
    sock.close()
    return data

def save_avatar(data, file_name):
    '''Saves the avatar data from get_avatar() in png format.'''
    local_file = open(file_name + '.png', 'w' + 'b')
    local_file.write(data)
    local_file.close()

def get_basic_info(player_name):
    '''Returns basic player statistics as a dictionary'''
    url = 'http://combatarms.nexon.net/ClansRankings'
    url += '/PlayerProfile.aspx?user=' + player_name
    sock = urlopen(url)
    html_raw = sock.read()
    sock.close()
    html_original_parse = BeautifulSoup(''.join(html_raw))
    player_info = html_original_parse.find('div', 'info').find('ul')
    basic_info_list = range(6)
    for i in basic_info_list:
        basic_info_list[i] = str(player_info('li', limit = 7)[i+1].contents[1])
    basic_info = dict(date = basic_info_list[0], rank = basic_info_list[1], kdr = basic_info_list[2], exp = basic_info_list[3], gp_earned = basic_info_list[4], gp_current = basic_info_list[5])
    return basic_info
下面是测试这些函数的代码:

from grabber import get_avatar, save_avatar, get_basic_info

player = raw_input('Player name: ')
print 'Downloading avatar...'
avatar_data = get_avatar(player)
file_name = raw_input('Save as? ')
print 'Saving avatar as ' + file_name + '.png...'
save_avatar(avatar_data, file_name)
print 'Retrieving ' + player + '\'s basic character info...'
player_info = get_basic_info(player)
print ''
print ''
print 'Info for character named ' + player + ':'
print 'Character creation date: ' + player_info['date']
print 'Rank: ' + player_info['rank']
print 'Experience: ' + player_info['exp']
print 'KDR: ' + player_info['kdr']
print 'Current GP: ' + player_info['gp_current']
print ''
raw_input('Press enter to close...')

如果我理解正确,您希望从一个位置获取图像,从另一个位置获取一些文本信息,在图像顶部绘制文本,然后返回标记的图像。我有这个权利吗


如果是这样,请获取Python图像库PIL。PIL和BeatifulSoup都能够直接从打开的URL读取内容,因此您可以忘记套接字的废话。从HTTP请求中获取播放器名称,打开图像,使用BeautifulSoup获取数据,使用PIL的文本函数在图像上写入,将图像保存回HTTP响应,就完成了。

非常感谢!非常感谢。修复了链接。很抱歉。我不知道发生了什么事。