如何在不转换为字符串的情况下将和拆分成几个部分

How to split a sum into its parts without converting to string in python(如何在不转换为字符串的情况下将和拆分成几个部分)
本文介绍了如何在不转换为字符串的情况下将和拆分成几个部分的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

假设我有一个表达式

from sympy import *
a,b,c,x,y = symbols('a c b x y') 
eq=a*x + b*x*y + c*y**2

需要拆分到包含单项的数组中。

我目前的解决方案是

parts = str(eq).split(' + ')

然后,我在要解释为表达式的数组部分的每个元素上使用val函数。

如何才能在不先将表达式转换为字符串的情况下将多元多项式拆分为单项式部分?

推荐答案

您可以explore a sympy expression using .func and .args

eq.func
> <class 'sympy.core.add.Add'>
eq.args
> (a*x, b*y**2, c*x*y)

这些参数中的每一个都是sympy表达式,可以通过相同的方式进行研究:

eq.args[0].func
> <class 'sympy.core.mul.Mul'
eq.args[0].args
> (a, x)

等等。请注意,在表达式树的最后一级,您需要.func.args以外的其他函数,例如:

eq.args[0].args[0].name  # the a in a*x
> 'a'
eq.args[1].args[1].args[1].n()  # the 2 in y**2
> 2.00000000000000

这篇关于如何在不转换为字符串的情况下将和拆分成几个部分的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)