-
Notifications
You must be signed in to change notification settings - Fork 3.5k
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Feature Request - repeatSourceRange Functionality in Worksheet #3895
base: master
Are you sure you want to change the base?
Feature Request - repeatSourceRange Functionality in Worksheet #3895
Conversation
…geCellsOfTheRanges
I don't understand how this works, or what is it supposed to do. So I checked your unit tests, but if I comment out How is this different than |
Thank you very much, @PowerKiKi Adrien, thank you for asking. I added this feature because of the limitation copyCells have by default. for sure in Excel, you can merge cells, but you can also copy merged cells to another place, given that the cells will maintain the same copy attribute. The logic, behind this, is that it could allow copying range cells programmatically, merged or non-merged, into a new location, but I also added higher functionality, at least as I faced a project from where this feature was inspired, to create copies by grinding (spread into certain position separated by space). For the tests, I'll take a look today most likely to see what can be improved there. Thanks again |
Copying the merged status of cells is a good improvement that could be accepted into PhpSpreadsheet. But repeating the copied cells sounds too specific to your use-case to live in PhpSpreadsheet. It won't get accepted. If you want "Copy the merged status of cells" in PhpSpreadsheet, then it should probably live within So |
@PowerKiKi it certainly makes sense what you wrote. The implementation I've written here, It's too specific, and thinking about it now, I have the same feeling. I could change it so that it only merges the cells that are (conventionally calling them simple) and the ranged cells where you have some range cells you want to copy. Thank you for the feedback |
This is:
Related to issue: #3894
Checklist:
Why this change is needed?
Provide an explanation of why this change is needed, with links to any Issues (if appropriate).
If this is a bugfix or a new feature, and there are no existing Issues, then please also create an issue that will make it easier to track progress with this PR.
Description:
This pull request introduces a new feature in the Worksheet class, the repeatSourceRange function. This function allows users to repeat a specified source range of cells multiple times in the worksheet. This is particularly useful when there is a need to duplicate a certain pattern or format of cells in a worksheet.
The repeatSourceRange function takes three parameters:
$worksheet: The worksheet where the source range is located and where the repetitions will be placed.
$sourceRange: The range of cells to be copied.
$repetitions: The number of times the source range should be repeated.
$groupSize: The number of rows in each group of repetitions.
Benefits:
Efficiency: This feature saves users from the tedious task of manually copying and pasting a range of cells multiple times. It automates the process, making it more efficient and less error-prone.
Consistency: By using this function, users can ensure that the repeated cells are identical, maintaining consistency in the worksheet.
Flexibility: This function is flexible and can be used in a variety of scenarios, such as creating multiple instances of a template within a worksheet, duplicating patterns, and more.
Ease of Use: This function is easy to use and integrates seamlessly with the existing PhpSpreadsheet library. Users can easily incorporate it into their projects without any major changes to their existing code.
Changes:
The main change is the addition of the repeatSourceRange function in the Worksheet class. Unit tests have also been added to ensure the correct functionality of this feature.
Testing:
Unit tests have been added to test the repeatSourceRange function. The tests cover basic functionality, such as copying cells and merged cells, and ensure that the cells are copied to the correct locations.
Please review and let me know if there are any changes or improvements needed