ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 7581|回复: 48

[推荐] 谢谢强悍的 liuzj2s大侠帮我写好的冲退货的公式,简直是神来之笔,继续求指点

[复制链接]

TA的精华主题

TA的得分主题

发表于 2009-8-27 19:31 | 显示全部楼层 |阅读模式
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
问题见附件,三个标黄色的单元格是我不知道怎么去处理了....
D列想要的结果是这样得来的:
A:
6-7是-1人,但这已经是最开始的值,保留些结果
5-12仍负,0
3-15仍负,0
-5-10仍负,0
10-20仍负,0
最后的值如果是负数,则0
B:
全是负数的情况下保留原值
全是负数的情况下保留原值
C:
1-2=-1,因为是最开始的数,保留
因为下面已经是正数,重新最后是负,0
10-6是正数,保留
-5-1仍负,0
最后的值如果是负数,则0

我刚在11楼尽我所能描述了一下规则,在这也贴上吧:
规则:
倒着看
1.最后一个值是负数的话,得0——即向前冲减
2.对中间的某个数来说,如果后面的数的和是负数分两种情况:
    (1)若当前数本身是负数,得0——继续向上冲;
     (2)如果当前数是正数,又分两种情况:
                            a.如果这个正数大于后面的负数和,刚当前数与后面的负数和的和作为此单元格的结果。
                            b.如果这个正数小于后面的负数和,分两种情况:
                                                          I.如果这个数已经是最开始的一条数据,刚此正数与后面的负数和的和为结果。
                                                          II.如果这个数不是开头的数据,继续向上冲

[ 本帖最后由 mrfox 于 2009-9-2 18:22 编辑 ]

sumproductv2.rar

4.87 KB, 下载次数: 46

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-8-27 22:46 | 显示全部楼层
哇,居然一晚上都没高手出现啊

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-8-27 23:23 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
我又试了试,好像没想出来统一的方法,目前我想的是,先按X,Y,Z三种情况判断,一种情况给一个公式,就不用统一公式了,会简单些吧

TA的精华主题

TA的得分主题

发表于 2009-8-27 23:37 | 显示全部楼层
D2=IF(AND(SUMPRODUCT(($A$2:$A$14=A2)*($B$2:$B$14))<0,SUMPRODUCT(($A$2:$A$14=A2)*($B$2:$B$14<0))>=1,SUMPRODUCT(($A$2:$A$14=A2)*($B$2:$B$14>0))>=1),"X",IF(SUMPRODUCT(($A$2:$A$14=A2)*($B$2:$B$14>0))<1,"Y",IF(AND(SUMPRODUCT(($A$2:$A$14=A2)*($B$2:$B$14))>0,SUMPRODUCT(($A$2:$A$14=A2)*($B$2:$B$14<0))>=1,SUMPRODUCT(($A$2:$A$14=A2)*($B$2:$B$14>0))>=1),"Z","")))  往下拉
好像你这个问题前几天也求助过了吧,当时没Z的要求

sumproduct.rar

4.33 KB, 下载次数: 25

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-8-27 23:52 | 显示全部楼层
dengjq2000啊,我是求救过,已经解决了(你看F列的公式),你理解错了,现在的问题是想让D列用公式得到C列我手工输入的想要的结果

TA的精华主题

TA的得分主题

发表于 2009-8-28 01:05 | 显示全部楼层

回复 5楼 mrfox 的帖子

你不说规则, 别人怎么帮啊. 只说你要这么个结果, 别人看不懂这个结果是代表什么, 怎么来的啊

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-8-28 09:01 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
谢谢LS的提醒,我把规则更新到一楼了,倒着看就明白了,请DX们出手吧

TA的精华主题

TA的得分主题

发表于 2009-8-28 10:12 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
A,C中作减法部分的规则不清楚,是减去后面的同类数求和的绝对值么?

=IF(SUMPRODUCT(-(A$2:A$14=A2),-(B$2:B$14>=0)),IF(COUNTIF(A2:A$14,A2)=COUNTIF(A$2:A$14,A2),B2-ABS(SUMPRODUCT(-(A3:A$14=A2),B3:B$14)),MAX(,B2-ABS(SUMPRODUCT(-(A3:A$14=A2),B3:B$14)))),B2)

[ 本帖最后由 liuzj2s 于 2009-8-28 10:53 编辑 ]

TA的精华主题

TA的得分主题

 楼主| 发表于 2009-8-28 10:38 | 显示全部楼层
我写完一楼的说明,忘记更新附件了,刚刚更新了,其实就是把说明放到右面一列里了

TA的精华主题

TA的得分主题

发表于 2009-8-28 10:40 | 显示全部楼层

回复 5楼 mrfox 的帖子

你是要想得C列的结果?但C列是如何得而来,因为你EXCEL文件里的求助描述上,看不你的规律,请再详细些
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-18 14:52 , Processed in 0.040940 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表