Я думаю, что было бы лучше создать массив из списка значений напрямую.
df
col new
0 abc [a, b, c]
1 def [d, e, f]
arr = np.array(df['new'].tolist())
arr
# array([['a', 'b', 'c'],
# ['d', 'e', 'f']], dtype='<U1')
arr.shape
# (2, 3)
Большой отказ от ответственности: Это будет работать, только если у всех списков есть одинаковое количество элементов. Если нет, это будет означать, что они являются рваными массивами, и numpy не сможет использовать эффективный формат памяти для представления вашего массива (следовательно, dtype='object'
).
pChart является другим большим PHP построение графика библиотеки.
Можно использовать api диаграммы Google для генерации диаграмм.
Ваш лучший выбор состоит в том, чтобы искать php_gd2. Это - довольно достойная библиотека изображений, которая идет с PHP (просто отключенный в php.ini), и мало того, что можно произвести законченные изображения в паре форматов, это имеет достаточно функций, что необходимо быть в состоянии привести в порядок хороший график довольно легко.
РЕДАКТИРОВАНИЕ: могло бы помочь, дал ли я Вам пару полезных ссылок:
http://www.libgd.org/ - можно получить последнее php_gd2
здесь
http://ca3.php.net/gd - php_gd
руководство.
Существует много библиотек, доступных для генерации графиков.
Более упоминается выше и здесь .
Существует также несколько библиотек построения графика, доступных для PHP для создания жизни более простой. JPGraph является хорошим (несвободным).
Понятия не имейте о gd2, но я сделал подобную вещь с gd, и это не было это трудно.
Переходят в http://www.php.net/ и ищут вещи как
, Это не столь роскошно как некоторые из тех другое решение там, но так как Вы генерируете изображение, это будет работать во всех браузерах. (кроме рыси...:-))
<час>/Johan
Обновление: я почти забыл, не используйте jpeg для этого типа изображений. jpeg артефакты будут действительно раздражающими, png является лучшим решением.
<?
# ------- The graph values in the form of associative array
$values=array(
"Jan" => 110,
"Feb" => 130,
"Mar" => 215,
"Apr" => 81,
"May" => 310,
"Jun" => 110,
"Jul" => 190,
"Aug" => 175,
"Sep" => 390,
"Oct" => 286,
"Nov" => 150,
"Dec" => 196
);
$img_width=450;
$img_height=300;
$margins=20;
# ---- Find the size of graph by substracting the size of borders
$graph_width=$img_width - $margins * 2;
$graph_height=$img_height - $margins * 2;
$img=imagecreate($img_width,$img_height);
$bar_width=20;
$total_bars=count($values);
$gap= ($graph_width- $total_bars * $bar_width ) / ($total_bars +1);
# ------- Define Colors ----------------
$bar_color=imagecolorallocate($img,0,64,128);
$background_color=imagecolorallocate($img,240,240,255);
$border_color=imagecolorallocate($img,200,200,200);
$line_color=imagecolorallocate($img,220,220,220);
# ------ Create the border around the graph ------
imagefilledrectangle($img,1,1,$img_width-2,$img_height-2,$border_color);
imagefilledrectangle($img,$margins,$margins,$img_width-1-$margins,$img_height-1-$margins,$background_color);
# ------- Max value is required to adjust the scale -------
$max_value=max($values);
$ratio= $graph_height/$max_value;
# -------- Create scale and draw horizontal lines --------
$horizontal_lines=20;
$horizontal_gap=$graph_height/$horizontal_lines;
for($i=1;$i<=$horizontal_lines;$i++){
$y=$img_height - $margins - $horizontal_gap * $i ;
imageline($img,$margins,$y,$img_width-$margins,$y,$line_color);
$v=intval($horizontal_gap * $i /$ratio);
imagestring($img,0,5,$y-5,$v,$bar_color);
}
# ----------- Draw the bars here ------
for($i=0;$i< $total_bars; $i++){
# ------ Extract key and value pair from the current pointer position
list($key,$value)=each($values);
$x1= $margins + $gap + $i * ($gap+$bar_width) ;
$x2= $x1 + $bar_width;
$y1=$margins +$graph_height- intval($value * $ratio) ;
$y2=$img_height-$margins;
imagestring($img,0,$x1+3,$y1-10,$value,$bar_color);imagestring($img,0,$x1+3,$img_height-15,$key,$bar_color);
imagefilledrectangle($img,$x1,$y1,$x2,$y2,$bar_color);
}
header("Content-type:image/png");
imagepng($img);
$_REQUEST['asdfad']=234234;
?>
Самым простым решением является использование Google Chart API. http://code.google.com/apis/chart/
Вы можете создавать гистограммы, круговые диаграммы, использовать 3D, и это так же просто, как создание URL-адреса с некоторыми параметрами. См. Простой пример ниже: